以下脚本实现在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的计划任务中,并根据需要调整运行的时间。