首页 > 数据库技术 > 详细

SqlServer自动备份作业

时间:2017-01-11 10:01:35      阅读:279      评论:0      收藏:0      [点我收藏+]

/*********完整备份作业*********
–完整备份,每周一次

USE Master
GO
declare @str varchar(100)
set @str=‘D:\DBtext\jgj\DBABak\FullBak‘+replace(replace(replace(convert(varchar,getdate(),20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘)+‘.bak‘
BACKUP DATABASE [Master] TO DISK=@str
WITH RETAINDAYS=15,NOFORMAT,NOINIT,
NAME=N‘Demo完整备份‘,SKIP,NOREWIND,
NOUNLOAD,STATS=10
GO

/*********差异备份作业*********
–截断日志

USE Master
GO
BACKUP LOG Demo  WITH NO_LOG
GO
--收缩日志文件
USE Demo
GO
DBCC SHRINKFILE (N‘Demo_log‘,0,TRUNCATEONLY)
GO
--差异备份,每天一次
USE Master
GO
declare @str varchar(100)
set @str=‘D:\DBtext\jgj\DBABak\DiffBak‘+replace(replace(replace(convert(varchar,getdate(),20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘)+‘.diff‘
BACKUP DATABASE [Demo] TO DISK=@str
WITH DIFFERENTIAL,RETAINDAYS=8,NOFORMAT,NOINIT,
NAME=N‘Demo差异备份‘,SKIP,NOREWIND,
NOUNLOAD,STATS=10
GO

/********日志备份作业*********
–日志备份,每小时一次

USE Demo
GO
declare @str varchar(100)
set @str=‘D:\DBtext\jgj\DBABak\logbak‘+replace(replace(replace(convert(varchar,getdate(),20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘)+‘.trn‘
BACKUP LOG [Demo] TO DISK=@str
WITH RETAINDAYS=3,NOFORMAT,NOINIT,
NAME=N‘Demo日志备份‘,SKIP,NOREWIND,
NOUNLOAD,STATS=10
GO

–删除过期的备份文件,每天两次

declare @str varchar(100),@dir varchar(100),@fileName varchar(30)
set @dir=‘del D:\DBtext\jgj\DBABak\‘
set @filename=left(replace(replace(replace(convert(varchar,getdate()-15,20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘),8)
set @str=@dir+‘fullbak‘+@filename+‘*.bak‘
exec xp_cmdshell @str
set @filename=left(replace(replace(replace(convert(varchar,getdate()-8,20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘),8)
set @str=@dir+‘diffbak‘+@filename+‘*.diff‘
exec xp_cmdshell @str
set @filename=left(replace(replace(replace(convert(varchar,getdate()-8,20),‘-‘,‘‘),‘ ‘,‘‘),‘:‘,‘‘),8)
set @str=@dir+‘logbak‘+@filename+‘*.trn‘
exec xp_cmdshell @str
 
 

SqlServer自动备份作业

原文:http://www.cnblogs.com/chengeng/p/6272369.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!