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

[经验分享] sql server 数据库的备份脚本

[复制链接]

尚未签到

发表于 2018-10-11 11:13:32 | 显示全部楼层 |阅读模式
  由于工作需要我需要编写一个sql server 数据库的备份脚本.需要实现的功能是:
  1. 能根据计划进行数据库的完全备份/增量备份.
  2. 将不同的备份内容存放在不同的备份设备上.(例如每天备份的内容单独存放在一个备份设备上).
  3.将备份的内容在其他的机器上面保存一份.
  实现的功能是:
  1.将需要执行的脚本放到计划任务当中.根据需要调整运行的时间.
  2.每次的备份内容生成单独的设备名称用日期文件名进行判断.
  3.将备份完的内容ftp到其他计算机上.这样也算是搞一个小的"异地容灾"不至于在一个机器完蛋后.数据库的备份没有了.
  下面就是这两个脚本的内容.欢迎大家提供意见也建议.
  另外就是本人不负责任何运行这些脚本的后果.但是有任何技术问题欢迎交流.如果是在我有时间和我知道的前提下.
  脚本分为两部分1个是完全备份的.另外一个是差异备份的.
  @ECHO off
  REM !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
  REM Differential Backup sql server database
  ECHO .
  REM Backup Database Script Log Files
  SET logdir=c:\1
  if not exist %logdir%\nul mkdir %logdir%
  REM B_SCRIPT_TARGET
  SET B_SCRIPT_TARGET=c:\2
  if not exist %B_SCRIPT_TARGET%\nul mkdir %B_SCRIPT_TARGET%
  REM B_DataFiles_TARGET
  SET B_DataFiles_TARGET=c:\3
  if not exist %B_DataFiles_TARGET%\nul mkdir %B_DataFiles_TARGET%
  REM Backup Database Name
  SET B_Database_Name=testdb
  SET B_DATE=%date:~0,4%%date:~5,2%%date:~8,2%
  ECHO use master ;>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO go >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO SP_ADDUMPDEVICE 'DISK',>>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO 'BackupDatabase%B_Database_Name%file%B_DATE%Differential', >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO '%B_DataFiles_TARGET%\%B_Database_Name%%B_DATE%_Differential.bak'; >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO go >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO BACKUP DATABASE %B_Database_Name% >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO TO BackupDatabase%B_Database_Name%file%B_DATE%Differential >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO WITH  NOINIT ,  NOUNLOAD ,  DIFFERENTIAL ; >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO go >>%B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  ECHO .
  REM osql.exe path
  SET OSQL_PATH=C:\Program Files\Microsoft SQL Server\80\Tools\Binn\
  REM Database user name and password
  SET DBUser=sa
  SET DBpassword=sapassword
  ECHO BACKUP DATABASE
  "%OSQL_PATH%osql.exe" -U %DBUser% -P %DBpassword% -i %B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql -o %logdir%\backupdatabase%B_DATE%_Differential.log
  REM FTP info
  set FTP_User=administrator
  set FTP_PW=adminpassword
  set FTP_IP=127.0.0.1
  set FTP_target=/database
  ECHO %FTP_User%>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO %FTP_PW%>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO bin>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO cd %FTP_target%>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO mput %B_DataFiles_TARGET%\%B_Database_Name%%B_DATE%_Differential.bak>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO BYE>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ftp -i -s:%B_SCRIPT_TARGET%\FTP_CMD.txt %FTP_IP%
  REM Delete Temp files
  DEL /Q %B_SCRIPT_TARGET%\DIFFERENTIAL_backup.sql
  DEL /Q %B_SCRIPT_TARGET%\FTP_CMD.txt
  完全备份:
  @ECHO off
  REM !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
  REM FULL backup sql server database
  REM email:hao.wangbj@gmail.com
  REM blog: http://wanghao.cublog.cn
  REM Date :20060905
  REM !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
  ECHO .
  REM Backup Database Script Log Files
  SET logdir=c:\1
  if not exist %logdir%\nul mkdir %logdir%
  REM B_SCRIPT_TARGET
  SET B_SCRIPT_TARGET=c:\2
  if not exist %B_SCRIPT_TARGET%\nul mkdir %B_SCRIPT_TARGET%
  REM B_DataFiles_TARGET
  SET B_DataFiles_TARGET=c:\3
  if not exist %B_DataFiles_TARGET%\nul mkdir %B_DataFiles_TARGET%
  REM Backup Database Name
  SET B_Database_Name=testdb
  SET B_DATE=%date:~0,4%%date:~5,2%%date:~8,2%
  ECHO use master ;>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO go >>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO SP_ADDUMPDEVICE 'DISK',>>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO 'BackupDatabase%B_Database_Name%file%B_DATE%_FULL', >>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO '%B_DataFiles_TARGET%\%B_Database_Name%%B_DATE%_FULL.bak'; >>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO go >>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO BACKUP DATABASE %B_Database_Name% >>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO TO BackupDatabase%B_Database_Name%file%B_DATE%_FULL >>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO WITH  NOINIT ,  NOUNLOAD ;>>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO go >>%B_SCRIPT_TARGET%\FULL_backup.sql
  ECHO .
  REM osql.exe path
  SET OSQL_PATH=C:\Program Files\Microsoft SQL Server\80\Tools\Binn\
  REM Database user name and password
  SET DBUser=sa
  SET DBpassword=sapassword
  ECHO BACKUP DATABASE
  "%OSQL_PATH%osql.exe" -U %DBUser% -P %DBpassword% -i %B_SCRIPT_TARGET%\FULL_backup.sql -o %logdir%\backupdatabase%B_DATE%_Full.log
  REM FTP info
  set FTP_User=administrator
  set FTP_PW=admin_password
  set FTP_IP=127.0.0.1
  set FTP_target=/database
  ECHO %FTP_User%>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO %FTP_PW%>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO bin>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO cd %FTP_target%>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO mput %B_DataFiles_TARGET%\%B_Database_Name%%B_DATE%_FULL.bak>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ECHO BYE>>%B_SCRIPT_TARGET%\FTP_CMD.txt
  ftp -i -s:%B_SCRIPT_TARGET%\FTP_CMD.txt %FTP_IP%
  REM Delete Temp files
  DEL /Q %B_SCRIPT_TARGET%\FULL_backup.sql
  DEL /Q %B_SCRIPT_TARGET%\FTP_CMD.txt


运维网声明 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.iyunv.com/thread-620317-1-1.html 上篇帖子: SQL Server 网络协议和 TDS 端点 下篇帖子: SQL Server基础二之彻底卸载SQL Server 2008 R2
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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