度量快速开发平台-专业、快速的软件定制快开平台

标题: 自动备份mssql server数据库并压缩的批处理脚本 [打印本页]

作者: 万望    时间: 2020-4-23 00:04
标题: 自动备份mssql server数据库并压缩的批处理脚本
1. set bakupfolder=F:\backup\
备份文件存放于目录F:\backup\ (此目录需要事先建好)
2. 默认每个数据库放置到bakupfolder下的同名的子目录(脚本自动创建)中;设置lay_in_subfolder=0后,将直接放置到bakupfolder
3. 备份文件名中自动添加备份时的时间字符串,不用担心备份目录下名字重复,也便于管理。
4. call :backupone foo
foo是需要备份的数据库,需要备份其它数据库,按同样的方式一行写一条即可
5. 命令行驱动备份操作:sqlcmd -U sa -P “sa” -S localhost -Q “xxx”
这里连接数据库的用户名密码都是sa,请改成你的实际用户名密码。mssql密码中如果有一些特殊字符,可能报错,所以加上双引号。如果密码简单,不加也可以;不过sa密码,一般都是很变态的吧~~


  1. @ECHO ON
  2. set d=%date:~0,10%
  3. set d=%d:-=%
  4. set t=%time:~0,8%
  5. set t=%t::=%
  6. set stamp=%p%%d%%t%
  7. set bakupfolder=F:\backup\
  8. rem 1按子目录保存备份文件;0不按
  9. set lay_in_subfolder=1
  10. call :backupone foo
  11. call :backupone foo2
  12. call :backupone foo3
  13. call :backupone foo4
  14. goto :EOF
  15. @ECHO OFF
  16. :backupone
  17. setlocal
  18. echo %1
  19. set dbname=%1
  20. if not exist %bakupfolder%%dbname% mkdir %bakupfolder%%dbname%
  21. if %lay_in_subfolder%==1 (
  22. set subfolder=%dbname%\
  23. )else set subfolder=
  24. rem echo %bakupfolder%%subfolder%%dbname%%stamp%.bak
  25. sqlcmd -U sa -P "sa" -S localhost -Q "backup database %dbname% to disk='%bakupfolder%%subfolder%%dbname%%stamp%.bak'"
  26. "C:\Program Files\WinRAR\RAR.exe" a -ep1 -r -o+ -m5 -s -df "%bakupfolder%%subfolder%%dbname%%stamp%".rar "%bakupfolder%%subfolder%%dbname%%stamp%.bak"
  27. endlocal&goto :EOF
复制代码



作者: 万望    时间: 2020-4-23 00:05
这是windows下,使用mssql命令行工具sqlcmd备份数据库,并调用rar压缩;不借助mssql"维护计划"功能
作者: 陈晓龙    时间: 2020-4-23 14:01
比oracle稍微复杂些样!




欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://bbs.delit.cn/) Powered by Discuz! X3.2