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