自动化SQL Server数据库备份脚本(含时间戳)

需积分: 38 11 下载量 142 浏览量 更新于2024-08-31 收藏 894B TXT 举报
本文档提供了一个自定义的SQL Server备份脚本,用于在实例级别进行全库备份操作。该脚本能够在指定的文件夹路径(如"E:\dbbak\")下,对除系统数据库(master, tempdb, model, msdb)之外的所有数据库进行全面备份。备份文件的命名规则是数据库名加上当前日期和时间(精确到秒),时间格式采用短日期-时间格式,中间以'-'分隔。 脚本的核心部分包含以下几个步骤: 1. **设置环境变量**: - 首先,使用`USE [master]`命令切换到master数据库。 - 接着,通过`SET ANSI_NULLS ON`和`SET QUOTED_IDENTIFIER ON`确保T-SQL语句兼容性和正确解析。 2. **创建存储过程**: - 使用`CREATE PROCEDURE BackupDatabase`定义一个名为BackupDatabase的存储过程,接受一个参数`@FolderPath`,用于指定备份文件的存放路径。 - 声明两个局部变量:`@FullPath`用于存储完整的备份文件路径,`@dbname`用于存储当前处理的数据库名。 - 创建一个名为`C_Backup`的游标,用于遍历所有非系统数据库。 3. **遍历数据库并执行备份**: - 使用`OPEN C_Backup`打开游标,然后通过`FETCH NEXT FROM C_Backup INTO @dbname`逐个获取数据库名。 - 对于每个数据库,计算出备份文件的完整路径,如`@FolderPath + @dbname + '_' + formatted_date + '.bak'`,其中`formatted_date`是格式化后的当前日期和时间。 - 使用`BACKUP DATABASE`语句将指定数据库备份到磁盘,并设置`WITH STATS=20`来记录备份统计信息。 - 循环继续,直到游标结束。 4. **关闭和释放资源**: - 当遍历完成后,使用`CLOSE C_Backup`关闭游标,然后`DEALLOCATE C_Backup`释放游标资源。 这个脚本可以在维护计划不可用的情况下手动执行,或者作为SQL Server作业的一部分定期运行,以确保数据库的定期备份。为了将其添加到SQL Server作业中,只需将存储过程`BackupDatabase`调用替换为作业步骤中的SQL文本,将`'E:\dbbak\'`替换为实际的备份路径即可。 这个脚本提供了一种实用的方法,简化了在多数据库环境中进行备份的工作流程,同时也方便了管理和恢复数据。然而,在实际部署时,可能需要根据具体环境调整路径和日志行为,以及考虑添加错误处理和通知机制。