oracle 自动备份 dmp 自动清理过期备份 ----------------------------
今日有客户需要自动备份成DMP文件,然后系统自动清理过期的DMP文件,保留3天就可以,因为客户数据比较小而且允许一定程度的丢失,所以每天晚上自动备份,然后自动清理最近三天以前的DMP文件,把脚本写在下面,如果有需要的人,复制粘贴过去,然后修改修改就行了。
下面是自动备份脚本,备份文件中用日期做文件名的一部分
UTOBACKUPDATABASE.BAT

exp FSEZGADATA/FSEZGADATA@bar2008 file=d:\backup\fsezgadata\%date:~0,10%.dmp log=d:\backup\fsezgadata\%date:~0,10%.log

下面是根据文件名中的日期删除DMP文件的脚本
AUTODELETEOLDBACKUPFILE.bat 这个不要直接运行,下面还要写个批处理文件来调用这个批处理文件

::请不要直接执行此文件

@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等备份方式来保证数据的不丢失。

---------数据恢复 oracle数据库恢复专家 13352468096 QQ:9417901 网站:http://www.sosdb.com-----