::请不要直接执行此文件
@echo off & setlocal ENABLEEXTENSIONS
call :Date2Day %date:~0,10% sdays
set /a sdays-=%1
call :Day2Date %sdays% difdate
echo 将删除 %2 下 %difdate% 前的修改的以下文件:
for /r %2 %%f in (*.dmp;*.log) do if "%%~tf" LEQ "%difdate%" del "%%f"
goto :EOF
:Date2Day
setlocal ENABLEEXTENSIONS
for /f "tokens=1-3 delims=/-, " %%a in ('echo/%1') do (
set yy=%%a & set mm=%%b & set dd=%%c
)
set /a dd=100%dd%%%100,mm=100%mm%%%100
set /a z=14-mm,z/=12,y=yy+4800-z,m=mm+12*z-3,j=153*m+2
set /a j=j/5+dd+y*365+y/4-y/100+y/400-2472633
endlocal&set %2=%j%&goto :EOF
:Day2Date
setlocal ENABLEEXTENSIONS
set /a i=%1,a=i+2472632,b=4*a+3,b/=146097,c=-b*146097,c/=4,c+=a
set /a d=4*c+3,d/=1461,e=-1461*d,e/=4,e+=c,m=5*e+2,m/=153,dd=153*m+2,dd/=5
set /a dd=-dd+e+1,mm=-m/10,mm*=12,mm+=m+3,yy=b*100+d-4800+m/10
(if %mm% LSS 10 set mm=0%mm%)&(if %dd% LSS 10 set dd=0%dd%)
endlocal&set %2=%yy%-%mm%-%dd%&goto :EOF
下面是删除过期DMP文件的脚本,实际上调用了上面的这个脚本文件。
autoclearolddbback.bat
:: 功能删除指定路径下指定日数以前修改的文件
:: 注意事项:参数1指定日数,昨天为1,前天为2,依次类推
:: 参数2指定文件路径,省略时将处理当前路径
:: 在第一次使用之前,请将要删除的文件备份然后再执行!!!!切记
:: 使用方法如:AUTODELETEOLDBACKUPFILE.bat 参数1 参数2
::请不要直接执行AUTODELETEOLDBACKUPFILE.bat
AUTODELETEOLDBACKUPFILE.bat 2 d:\backup\fsezgadata
然后把上面的两个文件放在计划任务里就可以,让系统自动备份以及自动删除过期的DMP文件。
当然了,前提是某些系统采用DMP备份的形式可以完成需要的数据备份,严格来说DMP备份不能说是备份,而是一种数据移植的方法,不过在某些情况下也可以应付一下。
如果重要的数据,建议采用RMAN等备份方式来保证数据的不丢失。