如何在最短时间内转移SQL server数据

海外服务器 (637) 2015-11-11 14:37:29

分析与设计思路

其实我们假设的环境有两个特点:第一个是数据库文件比较大;第二个就是我们的传送文件的速度可能会比较慢。也许这传送速度我们是没有办法了,但是我们可以就从文件的大小这个问题出发,结合SQL Server的特性,这样就有了下面的解决方案了。

为了使宕机时间最短,我们这里使用了完整备份和差异备份来迁移数据库,在白天的时候对需要迁移的数据库进行一次完整备份(XXX_full.bak),并把备份文件拷贝(这里可以使用FTP软件进行断点续传)到目标服务器进行还原,等到下班时间之后再进行一次差异备份(XXX_diff.bak),再把这个差异备份拷贝到目标服务器,在完整还原的基础上再进行差异还原。

这里的宕机时间 = 差异备份时间 + 传送差异备份文件时间 + 还原差异备份文件时间,这宕机时间是不是让你感觉这时间很短呢?

参考脚本

注意:修改下面脚本中数据库的名称,还有绝对路径。

完整备份

declare @dbname varchar(100)  

declare @sql nvarchar(max)  

set @dbname = 'DataBaseName' 

set @sql = '  

--'+@dbname+'_full   

BACKUP DATABASE ['+@dbname+']   

TO DISK = ''D:\DBBackup\'+@dbname+'_full.bak'' 

WITH NOFORMAT, NOINIT, NAME = '''+@dbname+'-完整数据库备份'',   

SKIP, NOREWIND, NOUNLOAD, STATS = 10  

GO'  

print @sql 

--生成的SQL

--DataBaseName_full   

BACKUP DATABASE [DataBaseName]   

TO DISK = 'D:\DBBackup\DataBaseName_full.bak' 

WITH NOFORMAT, NOINIT, NAME = 'DataBaseName-完整数据库备份',   

SKIP, NOREWIND, NOUNLOAD, STATS = 10  

GO 

完整备份还原

declare @dbname varchar(100)  

declare @sql nvarchar(max)  

set @dbname = 'DataBaseName' 

set @sql = '  

--RESTORE '+@dbname+'_full  

RESTORE DATABASE ['+@dbname+']   

FROM DISK = ''D:\DBBackup\'+@dbname+'_full.bak'' WITH FILE = 1,   

MOVE N''DataBase_Name'' TO N''D:\DataBase\'+@dbname+'.mdf'',   

MOVE N''DataBase_Name_log'' TO N''D:\DataBase\'+@dbname+'_log.ldf'',   

NORECOVERY, NOUNLOAD, REPLACE, STATS = 10  

GO'  

print @sql 

生成的SQL

--RESTORE DataBaseName_full  

RESTORE DATABASE [DataBaseName]   

FROM DISK = 'D:\DBBackup\DataBaseName_full.bak' WITH FILE = 1,   

MOVE N'DataBase_Name' TO N'D:\DataBase\DataBaseName.mdf',   

MOVE N'DataBase_Name_log' TO N'D:\DataBase\DataBaseName_log.ldf',   

NORECOVERY, NOUNLOAD, REPLACE, STATS = 10  

GO 

差异备份

declare @dbname varchar(100)  

declare @sql nvarchar(max)  

set @dbname = 'DataBaseName' 

set @sql = '  

--'+@dbname+'_diff  

BACKUP DATABASE ['+@dbname+']   

TO DISK = N''D:\DBBackup\'+@dbname+'_diff.bak'' 

WITH DIFFERENTIAL , NOFORMAT, NOINIT, NAME = N'''+@dbname+'-差异数据库备份'',   

SKIP, NOREWIND, NOUNLOAD, STATS = 10  

GO  

 

print @sql 

生成的SQL

--DataBaseName_diff  

BACKUP DATABASE [DataBaseName]   

TO DISK = N'D:\DBBackup\DataBaseName_diff.bak' 

WITH DIFFERENTIAL , NOFORMAT, NOINIT, NAME = N'DataBaseName-差异数据库备份',   
8. 

SKIP, NOREWIND, NOUNLOAD, STATS = 10  

GO 

差异备份还原

declare @dbname varchar(100)  

declare @sql nvarchar(max)  

set @dbname = 'DataBaseName' 

set @sql = '  

--RESTORE '+@dbname+'_full  

RESTORE DATABASE ['+@dbname+']   

FROM DISK = ''D:\DBBackup\'+@dbname+'_diff.bak'' WITH FILE = 1,   

NOUNLOAD, STATS = 10  

GO'  

print @sql 

生成的SQL

--RESTORE DataBaseName_full  

RESTORE DATABASE [DataBaseName]   

FROM DISK = 'D:\DBBackup\DataBaseName_diff.bak' WITH FILE = 1,   

NOUNLOAD, STATS = 10  

GO 

THE END