您的位置:首页 > 数据库

利用任务计划自动删除指定日期的SQLServer备份文件

2014-10-20 13:29 549 查看
出自:http://blog.csdn.net/babauyang/article/details/25742797

命令

FORFILES [/P pathname] [/M searchmask] [/S]

[/C command] [/D [+ | -] {yyyy-MM-dd | dd}]

方法1:

描述:可以删除7天以前的后缀名为log的日志文件。如今天是6.29,那么会删除6.22

号以前创建的文件。不会删除到回收站。

指定路径为要删除的文件夹路径,该批处理可以放在任意文件夹下。

forfiles /p D:\aizzw\LOG /m *.log -d -7 /c "cmd /c del /f @path"

参数解释:

这里的/p 指的是要删除的备份文件路径

/m 指的是要匹配的字符,通配符为*号,后缀名可以根据实际情况修改。

如zzw*.log;*.bak;*.txt

-d 指的是日期,“-d -7”指的是从但前日期当前日期往前减7天。

/c 指的是执行命令

@path 返回文件完整路径

方法2:

描述:可以删除7天以前的后缀名为log的日志文件。

不需要指定路径,必须放在要删除日志的文件下。删除当前文件夹下的匹配文件。

forfiles /m *.log -d -7 /c "cmd /c del /f @path"

以上批处理已经在windows 2003的虚拟机上测试通过

下面是这个命令的用法。

forfiles /p <目标目录名> /d <天数> /c <执行的命令>

看看列出的三个参数都有什么用处:

/p 指定了要在哪个目录里查找文件,默认是当前工作目录。

/d 指定一个日期或天数,用于比较文件的最后修改日期是否符合条件。

/c 对每个找到的文件执行的命令。

例1.要把在C盘根目录下最后修改日期大于或等于2007年7月1日的文件复制到D盘根目录下:

forfiles /p "c:\" /d "2007-7-1" /c "cmd /c copy @path d:\"

例2.删除在C盘backup目录下最后修改日期在10天前的文件:

forfiles /p "c:\backup" /d -10 /c "cmd /c echo deleting @file ... && del /f @path"

先看删除文件的代码

forfiles /p 包含要删除文件的完整路径(如:F:\Logfiles) /m *.log -d -7 /c "cmd /c del /f @path"

解释一下相关参数及命令

/p <Path> : 指定开始搜索文件的位置,如果不指定则默认为当前目录。

/m <SearchMask> : 文件查找所使用的通配符如代码中的"*.log"则为所有日志文件,当然也可以指定诸如"manmee_*.log"这样以manmee开头的所有日志文件。如果不指定此参数则默认为"*.*"。

/d [{+|-}][{<Date>|<Days>}] : 指定想选择文件的最后修改时间,上文中用了 "/d -7" 表示所有以当天为基础,7天以前的文件。当然这里还可以指定具体时间,例如:"/d -08/18/2009"这样所有早于2009年8月18日的文件。注意指定的时间必须是"MM/DD/YYYY"的格式。

/c 对所有文件以此执行指定的命令,命令体须在双引号(")内,默认是"cmd /c echo @file"。上文中用到的是"cmd /c del /f @path"删除指定文件。(这里的@file 和 @path 为变量,下文中将解释。)

下面说一下上文中用到的参数:

@PATH : 表示文件的完整的路径。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: