本篇文章为大家展示了这怎么在SQL Server编写一个自动备份脚本,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
创建SQL脚本
新建db_backup.sql
文件,填入以下内容。
-- 定义需要备份的数据库DECLARE @backupDatabase VARCHAR(20) = 'DB_NAME'-- 定义数据库备份文件存放的基础路径DECLARE @backupBasePath VARCHAR(MAX) = 'D:/DB_NAME/'-- 定义备份文件名,文件名格式:<DB>_backup_<yyyyMMdd>_<HH:mm:ss.SSS>.bakDECLARE @backupFileName VARCHAR(50) = NULL-- 获取当前时间戳DECLARE @backupTime DATETIME = CURRENT_TIMESTAMP-- 处理备份文件名称SET @backupFileName = @backupDatabase + '_backup_' + CONVERT(VARCHAR(25), @backupTime, 112) + '_' + REPLACE(CONVERT(VARCHAR(25), CURRENT_TIMESTAMP, 114), ':', '') + '.bak'-- 处理完整的备份文件路径SET @backupBasePath = @backupBasePath + @backupFileName-- 执行备份BACKUP DATABASE @backupDatabase TO DISK = @backupBasePath
脚本内容比较简单,这里就不展开说了。详情可查看:BACKUP (Transact-SQL)。
到这里已经可以使用脚本对数据库进行备份,但仍需手动执行脚本,无法实现自动定时备份的需求。
2. 创建批处理脚本
新建db_backup.bat
文件,填入以下内容。
sqlcmd -S localhost -U sa -P 123 -i ./db_backup.sql -o ./db_backup.log
以下为使用到的各个选项的解释:
sqlcmd -S <数据库连接地址> -U <数据库登录名> -P <数据库密码> -i <要执行的脚本文件> -o <执行日志文件>
更多选项请执行sqlcmd -?
查看或者查看:sqlcmd 实用工具。
双击执行批处理文件,如果没有报错且正常输出日志文件,则说明批处理脚本创建成功。
3. 创建Windows任务计划
使用win
+r
快捷键打开运行对话框,输入taskschd.msc
打开任务计划程序对话框,点击创建任务,依次进行以下步骤:
输入任务名称
如果是服务器环境,安全选项中务必选择不管用户是否登录都要运行
新建触发器
设置触发器为按预定计划执行一次
在触发器高级设置中选择重复任务间隔根据需要设置,持续时间设置为无限期。这样配置的结果就是在触发后,无限期地每隔xx时间段重复一次
新建操作
选择刚才新建的批处理脚本
检查批处理脚本中是否包含有关目录结构的语句,比如需要读写某个位置的文件。如果有且是Windows Server 2012及以后的操作系统,就需要配置起始位置,起始位置设置为批处理的目录即可。
上述内容就是这怎么在SQL Server编写一个自动备份脚本,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。