导读:在目前的工作中需要解决复制整个SqlServer数据库的问题,复制的内容包括数据库大纲、数据库中的存储过程、函数、表结构、主外键关系以及表中的所有数据等,也就是说copy版本与原数据库一模一样。经过一段时间的摸索,找到的一个比较简单的解决方案是:
(1)在复制数据库之前,先备份该数据库到文件。
(2)依据备份文件创建新的数据库,并Restore即可。
韩城网站建设公司创新互联公司,韩城网站设计制作,有大型网站制作公司丰富经验。已为韩城近1000家提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的韩城做网站的公司定做!
备份数据库可用如下Sql语句:
- string.Format("backup database {0} to disk = '{1}';", dbName, bakFilePath) 依据备份文件创建并Restore新数据库可以使用如下存储过程实现:
- CREATE PROCEDURE CopyDB
- (
- @newDbName varchar(50), --新数据库名称
- @dbDataDirPath varchar(100), --数据库安装的Data文件夹目录路径
- @soureDbName varchar(100), --源数据库名称
- @soureBackupFilePATH varchar(100)--源数据库备份文件的路径
- )
- AS
- declare @sql varchar(3000)
- set @sql='
- create database '+@newDbName+'
- ON
- (
- name='+@soureDbName+'_Data,
- filename='''+@dbDataDirPath+@newDbName+'_Data.mdf'',
- SIZE = 10,
- FILEGROWTH = 15%
- )
- LOG ON
- (
- name='''+@soureDbName+'_Log'',
- filename='''+@dbDataDirPath+@newDbName+'_Log.LDF'',
- SIZE = 5MB,
- MAXSIZE = 25MB,
- FILEGROWTH = 5MB
- )
- --开始还原
- RESTORE DATABASE '+@newDbName+' from disk='''+@soureBackupFilePATH+''' WITH REPLACE
- '
- exec(@sql)
- GO
测试的代码如下:
- IList
paraList = new List (); - SPParameter para1 = new SPParameter("newDbName", ParameterDirection.Input, "EASNew9");
- paraList.Add(para1);
- SPParameter para2 = new SPParameter("dbDataDirPath", ParameterDirection.Input, @"C:\Program Files\Microsoft SQL Server\MSSQL\Data\");
- paraList.Add(para2);
- SPParameter para3 = new SPParameter("soureDbName", ParameterDirection.Input, "AutoSchedulerSystem");
- paraList.Add(para3);
- SPParameter para4 = new SPParameter("soureBackupFilePATH", ParameterDirection.Input, @"d:\sqlDatabase\AutoSchedulerSystem");
- paraList.Add(para4);
- IDictionary
outParas = null; - Program.DataAccesser.GetSPAccesser(null).ExcuteNoneQuery("CopyDB", paraList, out outParas);
关于SqlServer数据库复制就为大家介绍这么多,相信通过上文中的介绍,大家对如何进行SqlServer数据库的复制已经有所了解,希望对大家有所帮助。
【编辑推荐】
本文题目:复制SqlServer数据库
链接URL:http://www.shufengxianlan.com/qtweb/news32/27682.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联