需求:因MSSQL2005备份无压缩功能,为节约空间对备份做压缩。

解决思路:查找备份目录下所有.bak备份文件压缩并删除原文件


命令如下:

FOR /R "D:\_SQL_DATA_BACK" %f in (*.bak) DO "C:\Program Files\WinRAR\WinRAR.exe" a -tk -ep1 -m5 -df -y "%f.rar" "%f"


bat脚本如下:

@echo off
FOR /R "D:\_SQL_DATA_BACK" %%f in (*.bak) DO "C:\Program Files\WinRAR\WinRAR.exe" a -tk -ep1 -m5 -df -y "%%f.rar" "%%f"
pause

注:%%是在批处理文件中变量符号,如果在CMD执行的话就应该是一个%。批处理文件在被解析的时候其中一个%被过滤掉,所以才用两个。


for循环使用方法:

FOR /R [[drive:]path] %variable   IN (set)   DO  command [command-parameters]

for   /R  [路径]   %variable传参(bat脚本使用%%f,命令%f)  in (set)    do 命令[command-parameters]


winrar参数解释:
    a    添加文件到压缩文件
    tk    保留原始压缩文件时间
    ep1    从名称中排除基本目录
    m<0..5> 设置压缩级别(0-存储3-默认5-最大)
    df    压缩后删除文件
    y     假设对全部询问都回答是