以下脚本实现在FTP服务器上恢复SQL server多个数据库的工作,先恢复整体备份,再恢复差异备份。整个脚本的运行过程自动写入rsdlog.log中,方便进行错误分析。此脚本使用前请务必参考文后的说明。

 

@echo off

color 27

title restoredb

 

rem andyxu

rem http://andyxu.blog.51cto.com

 

set nowtime=%date:~0,10% %time%

set today=%date:~0,10%

if "%time:~0,1%" == " " ( set nowh=%time:~1,1%) else ( set nowh=%time:~0,2%)

 

set yyyy=%date:~0,4%

set mm=%date:~5,2%

set dd=%date:~8,2%

 

for /l %%m in (1,1,9)do if %mm%==0%%m set mm=%%m

for /l %%d in (1,1,9)do if %dd%==0%%d set dd=%%d

 

set /a od=%dd%-1

if %od%==0 call :dd0 

if %mm%==0 call :mm0

if %od% LSS 9 set od=0%od:~-1,1%

if %mm% LSS 9 set mm=0%mm:~-1,1%

 

set yesterday=%yyyy%-%mm%-%od%

 

set rar="c:\Program Files\WinRAR\rar.exe"

set restordbedir=D:\backupdb\DbRestoredir

set backupdbdir=D:\backupdb

set rsdlog=D:\restore\rsdlog.log

 

@echo --------------------------- script begin>>  %rsdlog%

@echo %nowtime% >>  %rsdlog%

 

if %nowh% gtr 3 (set yesterday=%today%)

 

for %%a in (sqldb) do (

     cd /d %backupdbdir%\%%a

     %rar% e -o+ wz_%%a_%yesterday%.bak.rar     %backupdbdir%\%%a  >> %rsdlog%

     %rar% e -o+ cy_%%a_%today%_%nowh%.bak.rar     %backupdbdir%\%%a  >> %rsdlog%

     for  %%n in (sql1db sql2db log) do (

            @osql -s localhost -d master -E -Q "alter database %%n_%%a set offline with rollback after 10" >> %rsdlog%

            @osql -s localhost -d master -E -Q "restore database %%n_%%a    from disk = '%backupdbdir%\%%a\%%n_%%a_%yesterday%.bak'  with REPLACE,NORECOVERY,move '%%n_data'  to '%restordbedir%\%%n_%%a_data.mdf' ,move '%%n_log' to '%restordbedir%\%%n_%%a_log.ldf'" >> %rsdlog%

            @osql -s localhost -d master -E -Q "restore database %%n_%%a    from disk = '%backupdbdir%\%%a\cy_%%n_%%a_%today%.bak'  with RECOVERY,move '%%n_data'  to '%restordbedir%\%%n_%%a_data.mdf' ,move '%%n_log' to '%restordbedir%\%%n_%%a_log.ldf'" >> %rsdlog%

            @osql -s localhost -d master -E -Q "use %%n_%%a;exec sp_dropuser 'sqht';EXEC sp_adduser 'sqht';EXEC sp_addrolemember 'db_datareader', 'sqht'" >> %rsdlog%

     ) 

    

     for  %%n in (log) do (

      @osql -s localhost -d master -E -Q "use %%n_%%a;exec sp_dropuser 'logtest';EXEC sp_adduser 'logtest';EXEC sp_addrolemember 'db_datareader', 'logtest'" >> %rsdlog%

     

     )  

 

del *.bak       >> %rsdlog%

 

)

 

@echo ---------------------------script end >>  %rsdlog%

 

 

:dd0

set /a mm=%mm%-1

if %mm%==1 set od=31

if %mm%==2 call :2m

if %mm%==3 set od=31

if %mm%==4 set od=30

if %mm%==5 set od=31

if %mm%==6 set od=30

if %mm%==7 set od=31

if %mm%==8 set od=31

if %mm%==9 set od=30

if %mm%==10 set od=31

if %mm%==11 set od=30

if %mm%==12 set od=31

goto :eof 

 

:mm0

set /a yyyy=%yyyy%-1

set mm=12

set od=31

goto :eof 

 

:2m

set /a pddd=%yyyy%*10/4

set pd2d=%pddd:~-1,1%

set od=28

if %pd2d%==0 set od=29

goto :eof

 

说明:

1. 我的备份策略是每天进行一次完整备份,每2个小时进行一次差异备份,如果只做整体备份的话,那只需要将此脚本中恢复差异备份的语句注释或删除掉即可。

2. 此脚本是在FTP服务器上执行数据库的恢复工作,如果是在本地服务器上执行恢复的话,请自行修改脚本。

3. FTP的默认上传目录为D:\backup,数据库的备份文件实际是上传到了D:\backup\sqldb目录里,可根据需要自行修改脚本更改此目录。

4. FTP服务器上的数据库名称为原库名_sqldb,可根据需要自行修改脚本更改数据库名称。

5. 此脚本运行后会自动用sqht和logtest这两个帐号来测试,可根据需要自行修改脚本。

6. 脚本运行后会自动将mdf和ldf文件转移到D:\backupdb\DbRestoredir目录下,如不需要请自行修改脚本。

7. 加入了计算当前时间的语句,主要用于差异备份包的解压。

8. 需将此脚本保存为bat文件,并放入到sql server的计划任务中,并根据需要调整运行的时间。