如何使用FORFILES命令来删除SQL Server备份

如何使用FORFILES命令来删除SQL Server备份,第1张

我用xp_cmdshell命令和FORFILES命令来处理类似于你所列出的过程。可以从Microsoft

TechNet中获得FORFILES的可靠信息,但是在这篇文章中,我将涉及FORFILES大量的结构和使用方法来达到你的目的。

该FORFILES命令将选取文件的一个子集并且针对这个子集执行一个命令。这个命令需要下面的参数和接受下面的变量。

参数参数名描述/p路径/m检索屏蔽

(默认情况下是

*.*)

/s如果包含这个参数,那么子目录将会被递归地检索。

/c针对结果集中的每一个文件执行命令,命令必须包含在双引号中,默认情况是"cmd

c/

echo

@file"

/d针对文件选择的日期范围,把最新的更改日期当作文件标准。当/d参数是MM/DD/YYYY格式时,满足指定的+/-日期标准的文件也包含在内。当文件格式是smallint

(-32,768

-

32,768)文件+/-文件并且带着一个更改日期+/-时,从当前日期到该日期的时间数目将会包含在这个文件结果集中。

变量变量名描述

@FILE文件名

@FNAME无扩展的文件名

@EXT文件扩展名

@PATH文件绝对路经

@RELPATH文件的相对路径

@ISDIR如果文件类型是一个目录,那么判断是否是TRUE

@FSIZE文件大小(用字节衡量)

@FDATE文件上的最新更改日期邮戳

@FTIME文件上的最新更改时间邮戳

利用这些参数可以构造下面的例子来解决你删除备份脚本文件的难题。你可以基于更改时间/日期或者备份类型来创建脚本。你甚至可以构造能够同时参照两种标准的脚本。

我们将仔细看看这些可能的脚本。记住,你将从T-SQL代码内部执行这个过程,所以你需要在一个xp_cmdshell访问中以EXEC

xp_cmdshell

'FORFILES

COMMAND'的格式总结这些语句。请注意,在所有的例子中我都会使用/Q

/F标签来作为删除命令。这意味着这个命令将使用安静模式(/Q)甚至删除只能读的文件(/F)。

例子当文件更改日期晚于10/18/2008时,删除所有C:Backup目录和它子目录下的.sql文件。

EXEC

xp_cmdshell

'FORFILES

/p

c:BACKUP

/s

/m

*.sql

/d

10/18/2008

/c

"CMD

/C

del

/Q

/F

@FILE"'

当文件更改日期多于30天时,删除所有C:Backup目录和它的子目录下的.sql文件。

EXEC

xp_cmdshell

'FORFILES

/p

c:BACKUP

/s

/m

*.sql

/d

-30

/c

"CMD

/C

del

/Q

/F

@FILE"'

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

declare @str varchar(100),@dir varchar(100),@fileName varchar(30)

set @dir='del D:\Weldon\'

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


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/tougao/8067047.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存