1. 程式人生 > >oracle 刪除備份檔案兩種方式

oracle 刪除備份檔案兩種方式

執行後會在相同目錄下生成日誌檔案:DelExpiredLog.log現實執行的起始時間點。
@echo off
rem write to log
set filename=DelExpiredLog.log
echo -------------------Delete Expired Log Files------------------------- >>%filename%
echo Start >>%filename%
echo (%date% %time%) >>%filename%
echo Delete the expired log files in 目標目錄路徑1, Please wait... >>%filename%
forfiles  /p "目標目錄路徑1" /m *.* /d -3 /c "cmd /c del @path"
echo Delete the expired log files in 目標目錄路徑2, Please wait... >>%filename%
forfiles  /p "目標目錄路徑2" /m *.* /d -3 /c "cmd /c del @path"
echo End >>%filename%
echo (%date% %time%) >>%filename%
exit

FORFILES  [/P pathname] [/M searchmask] [/S] [/C command] [/D [+ | -] {yyyy-MM-dd | dd}]

描述:
選擇一個檔案(或一組檔案)並在那個檔案上
執行一個命令。這有助於批處理作業。

引數列表:
/P pathname 表示開始搜尋的路徑。預設資料夾是當前工作的
目錄 (.)。

/M searchmask 根據搜尋掩碼搜尋檔案。預設搜尋掩碼是 '*'。

/S 指導 forfiles 遞迴到子目錄。像 "DIR /S"。

/C command 表示為每個檔案執行的命令。命令字串應該
用雙引號括起來。

預設命令是 "cmd /c echo @file"。下列變數
可以用在命令字串中:
@file - 返回檔名。
@fname - 返回不帶副檔名的檔名。
@ext - 只返回檔案的擴充套件。
@path - 返回檔案的完整路徑。
@relpath - 返回檔案的相對路徑。
@isdir - 如果檔案型別是目錄,返回 "TRUE";
如果是檔案,返回 "FALSE"。
@fsize - 以位元組為單位返回檔案大小。
@fdate - 返回檔案上一次修改的日期。
@ftime - 返回檔案上一次修改的時間。

要在命令列包括特殊字元,字元請以 0xHH
形式使用十六進位制程式碼(例如,0x09 為 tab)。
內部 CMD.exe 命令前面應以 "cmd /c" 開始。

/D date 選擇檔案,其上一次修改日期大於或等於 (+),
或者小於或等於 (-) 用 "yyyy-MM-dd" 格式指定的日期;
或選擇檔案,其上一次修改日期大於或等於 (+)
當前日期加 "dd" 天,或者小於或等於 (-) 當前
日期減 "dd" 天。有效的 "dd" 天數可以是
0 - 32768 範圍內的任何數字。如果沒有指定,
"+" 被當作預設符號。

/? 顯示幫助訊息。

例如:
FORFILES /?
FORFILES
FORFILES /P C:\WINDOWS /S /M DNS*.*
FORFILES /S /M *.txt /C "cmd /c type @file | more"
FORFILES /P C:\ /S /M *.bat
FORFILES /D -30 /M *.exe
/C "cmd /c echo @path 0x09 在 30 前就被更改。"
FORFILES /D 2001-01-01
/C "cmd /c echo @fname 在 2001年1月1日就是新的。"
FORFILES /D +2006-11-25 /C "cmd /c echo @fname 今天是新的。"
FORFILES /M *.exe /D +1
FORFILES /S /M *.doc /C "cmd /c echo @fsize"
FORFILES /M *.txt /C "cmd /c if @isdir==FALSE notepad.exe @file"

刪除三十天前的檔案forfiles /p "d:\108" /s /m *.* /d -30 /c "cmd /c del @path"