[Irving] SQL 2005/SQL 2008 备份数据库并自动删除N天前备份的脚本

时间:2022-11-06 00:48:09

以下为SQL脚本,本人以执行计划来调用,所以改成了执行命令,大家可根据自己需要改为存储过程使用

DECLARE @bak_path nvarchar(4000)='E:\MsBackUp\SqlAutoBackup\'       --备份路径;
DECLARE @baktype int = 0 --备份类型为全备,1为差异备,2为日志备份
DECLARE @type int = 3 --设置需要备份的库,0为全部库,1为系统库,2为全部用户库,3为指定库,4为排除指定库;
DECLARE @dbnames nvarchar(4000)='DB_ERP_JD,DB_WMS_JD,DB_FMS_JD,TEST_ERP_JD,TEST_WMS_JD,TEST_FMS_JD' --需要备份或排除的数据库,用,隔开,当@type=3或4时生效
DECLARE @overdueDay int = 0 --设置过期天数,默认天;
DECLARE @compression int =0 --是否采用sql2008的压缩备份,0为否,1为采用压缩 --sql server 2005/2008备份/删除过期备份T-sql 版本v1.0
/*
desc :适用于sql2005/2008备份,自动生成库文件夹,可以自定义备份类型和备份库名等
可以自定义备份过期的天数
删除过期备份功能不会删除最后一次备份,哪怕已经过期
如果某库不再备份,那么也不会再删除之前过期的备份
如有错误请指正,谢谢.
*/ set nocount on
--开启xp_cmdshell支持
exec sp_configure 'show advanced options', 1
reconfigure with override
exec sp_configure 'xp_cmdshell', 1
reconfigure with override
exec sp_configure 'show advanced options', 0
reconfigure with override
print char(13)+'------------------------' --判断是否填写路径
if isnull(@bak_path,'')=''
begin
print('error:请指定备份路径')
return
end --判断是否指定需要备份的库
if isnull(ltrim(@baktype),'')=''
begin
print('error:请指定备份类型aa:0为全备,1为差异备,2为日志备份')
return
end
else
begin
if @baktype not between 0 and 2
begin
print('error:指定备份类型只能为,1,2: 0为全备,1为差异备,2为日志备份')
return
end
end
--判断是否指定需要备份的库
if isnull(ltrim(@type),'')=''
begin
print('error:请指定需要备份的库,0为全部库,1为系统库,2为全部用户库,3为指定库,4为排除指定库')
return
end
else
begin
if @type not between 0 and 4
begin
print('error:请指定需要备份的库,0为全部库,1为系统库,2为全部用户库,3为指定库,4为排除指定库')
return
end
end --判断指定库或排除库时,是否填写库名
if @type>2
if @dbnames=''
begin
print('error:备份类型为'+ltrim(@type)+'时,需要指定@dbnames参数')
return
end --判断指定指定过期时间
if isnull(ltrim(@overdueDay),'')=''
begin
print('error:必须指定备份过期时间,单位为天,0为永不过期')
return
end --判断是否支持压缩
if @compression=1
if charindex('',@@version)=0 or charindex('Enterprise',@@version)=0
begin
print('error:压缩备份只支持sql2008企业版')
return
end --判断是否存在该磁盘
declare @drives table(drive varchar(1),[size] varchar(20))
insert into @drives exec('master.dbo.xp_fixeddrives')
if not exists(select 1 from @drives where drive=left(@bak_path,1))
begin
print('error:不存在该磁盘:'+left(@bak_path,1))
return
end --格式化参数
select @bak_path=rtrim(ltrim(@bak_path)),@dbnames=rtrim(ltrim(@dbnames))
if right(isnull(@bak_path,''),1)!='' set @bak_path=@bak_path+''
if isnull(@dbnames,'')!='' set @dbnames = ','+@dbnames+','
set @dbnames=replace(@dbnames,' ','') --定义变量
declare @bak_sql nvarchar(max),@del_sql nvarchar(max),@i int,@maxid int
declare @dirtree_1 table (id int identity(1,1) primary key,subdirectory nvarchar(600),depth int,files int)
declare @dirtree_2 table (id int identity(1,1) primary key,subdirectory nvarchar(600),depth int,files int,
dbname varchar(300),baktime datetime,isLastbak int)
declare @createfolder nvarchar(max),@delbackupfile nvarchar(max),@delbak nvarchar(max) --获取需要备份的库名--------------------start
declare @t table(id int identity(1,1) primary key,name nvarchar(max))
declare @sql nvarchar(max)
set @sql = 'select name from sys.databases where state=0 and name!=''tempdb'' '
+ case when @baktype=2 then ' and recovery_model!=3 ' else '' end
+ case @type when 0 then 'and 1=1'
when 1 then 'and database_id<=4'
when 2 then 'and database_id>4'
when 3 then 'and charindex('',''+Name+'','','''+@dbnames+''')>0'
when 4 then 'and charindex('',''+Name+'','','''+@dbnames+''')=0 and database_id>4'
else '1>2' end
insert into @t exec(@sql)
--获取需要备份的库名---------------------end --获取需要创建的文件夹------------------start
insert into @dirtree_1 exec('master.dbo.xp_dirtree '''+@bak_path+''',0,1')
select @createfolder=isnull(@createfolder,'')+'exec master.dbo.xp_cmdshell ''md '+@bak_path+''+name+''',no_output '+char(13)
from @t as a left join @dirtree_1 as b on a.name=b.subdirectory and b.files=0 and depth=1 where b.id is null
--获取需要创建的文件夹-------------------end --生成处理过期备份的sql语句-------------start
if @overdueDay>0
begin
insert into @dirtree_2(subdirectory,depth,files) exec('master.dbo.xp_dirtree '''+@bak_path+''',0,1')
if @baktype =0
delete from @dirtree_2 where depth=1 or files=0 or charindex('_Full_bak_',subdirectory)=0
if @baktype =1
delete from @dirtree_2 where depth=1 or files=0 or charindex('_Diff_bak_',subdirectory)=0
if @baktype=2
delete from @dirtree_2 where depth=1 or files=0 or charindex('_Log_bak_',subdirectory)=0
if exists(select 1 from @dirtree_2)
delete from @dirtree_2 where isdate(
left(right(subdirectory,19),8)+' '+ substring(right(subdirectory,20),11,2) + ':' +
substring(right(subdirectory,20),13,2) +':'+substring(right(subdirectory,20),15,2)
)=0
if exists(select 1 from @dirtree_2)
update @dirtree_2 set dbname = case when @baktype=0 then left(subdirectory,charindex('_Full_bak_',subdirectory)-1)
when @baktype=1 then left(subdirectory,charindex('_Diff_bak_',subdirectory)-1)
when @baktype=2 then left(subdirectory,charindex('_Log_bak_',subdirectory)-1)
else '' end
,baktime=left(right(subdirectory,19),8)+' '+ substring(right(subdirectory,20),11,2) + ':' +
substring(right(subdirectory,20),13,2) +':'+substring(right(subdirectory,20),15,2)
from @dirtree_2 as a
delete @dirtree_2 from @dirtree_2 as a left join @t as b on b.name=a.dbname where b.id is null
update @dirtree_2 set isLastbak= case when (select max(baktime) from @dirtree_2 where dbname=a.dbname)=baktime
then 1 else 0 end from @dirtree_2 as a
select @delbak=isnull(@delbak,'')+'exec master.dbo.xp_cmdshell ''del '+@bak_path+''+dbname+''
+subdirectory+''',no_output '+char(13) from @dirtree_2 where isLastbak=0 and datediff(day,baktime,getdate())>@overdueDay
end
--生成处理过期备份的sql语句--------------end begin try
print(@createfolder) --创建备份所需文件夹
exec(@createfolder) --创建备份所需文件夹
end try
begin catch
print 'err:'+ltrim(error_number())
print 'err:'+error_message()
return
end catch select @i=1 ,@maxid=max(id) from @t
while @i<=@maxid
begin
select @bak_sql=''+char(13)+'backup '+ case when @baktype=2 then 'log ' else 'database ' end
+quotename(Name)+' to disk='''+@bak_path + Name+''+
Name+ case when @baktype=0 then '_Full_bak_' when @baktype=1 then '_Diff_bak_'
when @baktype=2 then '_Log_bak_' else null end + case when @compression=1 then 'compression_' else '' end+
replace(replace(replace(convert(varchar(20),getdate(),120),'-',''),' ','_'),':','')+
case when @baktype=2 then '.trn' when @baktype=1 then '.dif' else '.bak' end +''''
+ case when @compression=1 or @baktype=1 then ' with ' else '' end
+ case when @compression=1 then 'compression,' else '' end
+ case when @baktype=1 then 'differential,' else '' end
+ case when @compression=1 or @baktype=1 then ' noformat' else '' end
from @t where id=@i
set @i=@i+1
begin try
print(@bak_sql)--循环执行备份
exec(@bak_sql) --循环执行备份
end try
begin catch
print 'err:'+ltrim(error_number())
print 'err:'+error_message()
end catch
end begin try
print(@delbak) --删除超期的备份
exec(@delbak) --删除超期的备份
end try
begin catch
print 'err:'+ltrim(error_number())
print 'err:'+error_message()
end catch --关闭xp_cmdshell支持
exec sp_configure 'show advanced options', 1
reconfigure with override
exec sp_configure 'xp_cmdshell', 1
reconfigure with override
exec sp_configure 'show advanced options', 0
reconfigure with override

[Irving] SQL 2005/SQL 2008 备份数据库并自动删除N天前备份的脚本的更多相关文章

  1. shell 自动删除n天前备份

    Linux自动删除n天前备份Linux是一个很能自动产生文件的系统,日志.邮件.备份等.因此需要设置让系统定时清理一些不需要的文件.语句写法:     find 对应目录 -mtime +天数 -na ...

  2. SqlServer 自动备份、自动删除7天前备份

    -----sqlserver 数据异地备份 默认删除 七天前的数据 -----该代码可配置成SQLServer作业里做调度,或者配置成任务计划进行执行 ----挂载异地盘符 exec master.. ...

  3. liunx定时备份mongo数据库并实现自动删除N天前备份

    1.脚本文件: #!/bin/sh # dump 命令执行路径,根据mongodb安装路径而定 #!/bin/sh # dump 命令执行路径,根据mongodb安装路径而定 /bin/mongodu ...

  4. Linux Mysql8每天定时备份数据库并自动删除7天之前的备份

    在某一文件夹下创建shell文件: vi /var/spool/cron/mysqlbak.sh 复制如下内容: #!/bin/bash # Name:name.sh backupdir=/www/m ...

  5. Linux自动删除n天前备份

    Linux是一个很能自动产生文件的系统,日志.邮件.备份等.因此需要设置让系统定时清理一些不需要的文件. 语句写法: find 对应目录 -mtime +天数 -name "文件名&quot ...

  6. Sql Server自动备份数据库,定期删除备份

    //实现:每天自动备份数据库,定期删除备份 //步骤:[开始]--[所有程序]--[Microsoft SQL Server 2005]--[SQL Server Management Studio] ...

  7. Windows环境下Oracle数据库的自动备份脚本自动删除30天前的备份

    @echo off echo ================================================ echo Windows环境下Oracle数据库的自动备份脚本 echo ...

  8. oracle&lowbar;自动备份用户数据,删除N天前的旧数据(非rman,bat&plus;vbs)

    有时数据没有实时备份恢复那么高的安全性需求,但每天 ,或者定期备份表结构 和数据依旧是很有必要的,介绍一种方法 在归档和非归档模式均可使用的自动备份方法. 预期效果是备份用户下的数据含表结构,备份文件 ...

  9. Linux下定时切割Mongodb数据库日志并删除指定天数前的日志记录

    此为在网络上找来的,觉得很好! 实现目的: 对Mongodb数据库日志按天保存,并且只保留最近7天的日志记录. 具体操作: 使用Mongodb数据库自带的命令来切割日志 ps -def | grep ...

随机推荐

  1. KNN算法

    1.算法讲解 KNN算法是一个最基本.最简单的有监督算法,基本思路就是给定一个样本,先通过距离计算,得到这个样本最近的topK个样本,然后根据这topK个样本的标签,投票决定给定样本的标签: 训练过程 ...

  2. 【android-tips】如何在view中取得activity对象

    (转载请注明出处:http://blog.csdn.net/buptgshengod) 今天想实现在view中返回上一个activity的功能,想了半天.因为在虽然view是包含于一个activity ...

  3. 如何使用coding&period;net

        由于我有一位十分聪明能干的室友会使用coding.net,于是我决定奉献一下室友的智慧,告诉大家如何使用conding.net上交作业.(如有说错的地方希望大家可以指出来) 首先登陆codin ...

  4. top指令

    top - :: up :, user, load average: 0.00, 0.01, 0.05 Tasks: total, running, sleeping, stopped, zombie ...

  5. ASP多行多列显示代码

    <table width="98%" border="0" align="center"> <tr> <% S ...

  6. Oracle 11g 的server结果缓存result&lowbar;cache&lowbar;mode

    对于常常要查的结果集,返回少量记录,server端是能够缓存的,结果集保存在共享池中,假设是绑定变量,绑定变量的值也要一样. SQL> show parameter result_cache N ...

  7. android中使用surfaceview+MediaPlayer播放视频

    Android中播放视频主要有两种方式: 使用其自带的播放器.指定Action为ACTION_VIEW,Data为Uri,Type为其MIME类型 使用android自带的VideoView,这种方法 ...

  8. 怎么调用api接口

    api的简单调用,调用api的方法 方法一:用前端方法调用api 完整代码: <!DOCTYPE html> <html lang="en"> <he ...

  9. NET设计模式 第二部分 结构性模式&lpar;14&rpar;:结构型模式专题总结

    ——探索设计模式系列之十五 Terrylee,2006年5月 摘要:结构型模式,顾名思义讨论的是类和对象的结构,它采用继承机制来组合接口或实现(类结构型模式),或者通过组合一些对象,从而实现新的功能( ...

  10. 在JSP中如何使用JavaBean

    在JSP中使用JavaBean以后,可以实现HTML代码和Java代码的分离,是JSp更易于开发和维护.因此JavaBean成了JSP程序员必备的利器.虽然javaBean是java类,但是它也有自己 ...