SQL自动备份及自动删除5天前旧有备份-杜小杰
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> ADP及SQL SERVER


SQL自动备份及自动删除5天前旧有备份

发表时间:2012/1/17 16:14:17 评论(0) 浏览(7973)  评论 | 加入收藏 | 复制
   
摘 要:SQL SERVER 2005里自动备份数据库和删除旧有备份 
正 文:

打开SQL SERVER MANAGEMENT STUDIO,启动SQL SERVER代理服务(注意在控制面板-管理工具-服务中设置SQL SERVER AGENT的启动类型为自动)。启动后点击作业-新建作业,弹出一个作业属性的窗口,在常规栏目里可以先给作业命名,假设为备份数据

 一、备份数据的第一个步骤--“备份当日数据” 

步骤栏目里新建一个步骤名为备份当日数据,类型为“T-SQL”,数据库选择你要操作的数据库(假设为“TESTDB”),命令窗口里填入备份的SQL语句。假设备份数据放在“D:\BACKUP”里,备份文件命名格式为“SQL-2009-3-26.BAK”,那么语句如下:

DECLARE @filename VARCHAR(255)
DECLARE @date DATETIME

Select @date=GETDATE()
Select @filename = 'D:\BACKUP\SQL-'+CAST(DATEPART(yyyy,@date) as varchar)+'-'+CAST(DATEPART(mm,@date) as varchar)+'-'+CAST(DATEPART(dd,@date) as varchar)+'.bak'

BACKUP DATABASE [TESTDB] TO  DISK = @filename WITH INIT
GO

 在步骤属性的高级的成功时要执行的操作选择转到下一步即可,这样备份当日数据的步骤已经建立好。

 二、备份数据的第二个步骤--“删除旧有备份

 我们可以设置只保留5天内的备份数据,那么必须删除5天前的数据备份文件。在备份数据作业属性窗口的步骤栏目里,建立第二个步骤命名为删除旧有备份。同样类型为“T-SQL”,命令窗口里填入一下SQL语句:

 DECLARE @OLDDATE DATETIME
Select @OLDDATE=GETDATE()-5
EXECUTE master.dbo.xp_delete_file 0,N'D:\BACKUP',N'bak',@olddate

 此命令会删除“D:\BACKUP”5天前的.BAK.TRN格式的文件,不用指定文件名是什么。因为SQL SERVER的备份文件里包含了时间属性在里面。在步骤属性的高级的成功时要执行的操作选择退出报告成功的作业即可,这样第二个步骤已经建立好。

 三、备份数据作业属性的计划栏目里,设置作业的执行时间

 新建一个作业计划,命名为每日自动备份和删除,再选择执行的周期,例如每天凌晨1点开始执行。

 最后保存整个备份数据的作业,每日就会自动备份数据库和删除旧有数据了。


Access软件网交流QQ群(群号:198465573)
 
 相关文章
[基础知识]关于自动备份的例子  【cuxun  2008/1/8】
[源码]按日期自动备份当前数据库  【点燃一支烟  2009/10/8】
自动备份定量的备份文件  【jia  2012/5/7】
常见问答
技术分类
相关资源
文章搜索
关于作者

杜小杰

文章分类

文章存档

友情链接