设为首页 收藏本站
查看: 1491|回复: 0

[经验分享] SQL server备份与恢复脚本(三):还原

[复制链接]

尚未签到

发表于 2018-10-14 12:42:21 | 显示全部楼层 |阅读模式
  以下脚本实现在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的计划任务中,并根据需要调整运行的时间。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-621494-1-1.html 上篇帖子: 【Sql Server】2.SQL Server 2008管理工具 下篇帖子: MS SQL Server数据库压缩备份
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表