因服务器安装的SQL Server版本不支持自动定时备份,需自行实现,大概思路为: 创建备份数据库的脚本 创建批处理脚本执行步骤一中的脚本 创建windows定时任务执行步骤二中的脚本 1. 创建sql脚本 新建db_backup.s
因服务器安装的SQL Server版本不支持自动定时备份,需自行实现,大概思路为:
新建db_backup.sql
文件,填入以下内容。
-- 定义需要备份的数据库
DECLARE @backupDatabase VARCHAR(20) = "DB_NAME"
-- 定义数据库备份文件存放的基础路径
DECLARE @backupBasePath VARCHAR(MAX) = "D:/DB_NAME/"
-- 定义备份文件名,文件名格式:_backup__.bak
DECLARE @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)。
到这里已经可以使用脚本对数据库进行备份,但仍需手动执行脚本,无法实现自动定时备份的需求。
新建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 实用工具。
双击执行批处理文件,如果没有报错且正常输出日志文件,则说明批处理脚本创建成功。
使用win
+r
快捷键打开运行对话框,输入taskschd.msc
打开任务计划程序对话框,点击创建任务,依次进行以下步骤:
完成以上步骤后即创建任务成功,然后选中新创建的任务,点击右键选择运行,可测试任务是否可正常执行。
--结束END--
本文标题: SQL Server使用脚本实现自动备份
本文链接: https://www.lsjlt.com/news/8177.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-12
2024-05-12
2024-05-12
2024-05-12
2024-05-11
2024-05-11
2024-05-11
2024-05-11
2024-05-11
2024-05-11
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0