当前位置: 移动技术网 > IT编程>数据库>MSSQL > sqlserver 复制表 复制数据库存储过程的方法

sqlserver 复制表 复制数据库存储过程的方法

2017年12月12日  | 移动技术网IT编程  | 我要评论

47军,关于鸟的天堂的资料,unity3d论坛

在目前的工作中需要解决复制整个sqlserver数据库的问题,复制的内容包括数据库大纲、数据库中的存储过程、函数、表结构、主外键关系以及表中的所有数据等,也就是说copy版本与原数据库一模一样。经过一段时间的摸索,找到的一个比较简单的解决方案是: 
(1)在复制数据库之前,先备份该数据库到文件。 
(2)依据备份文件创建新的数据库,并restore即可。 
备份数据库可用如下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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网