oracle数据每天备份(导出dmp)并清理老备份文件的脚本
1、创建目录和文件
a)E:\scripts\ (作用:放置脚本和临时工作目录)
b)E:\bak (作用:存放备份数据)
2、这台windows机器安装完整的oracle客户端,并可以连接到
oracle。
3、在另外一台windows系统机器上做定时任务,每天将oracle
数据导出并压缩。
a)新建文件bak.cmd 内容:
:: 设置日期变量
FOR /F "tokens=1,2,3 delims=- " %%i IN ('DATE /T') DO SET D=%%i%%j%%k
:: 执行oracle导出命令
exp 用户/密码@数据库file=E:\scripts\data%D%.dmp statistics=none grants=n
rows=y log=E:\scripts\data%D%.log
cd E:\scripts
:: 压缩dmp文件
"C:\Program Files\WinRAR\WinRAR.exe" a -afzip -k -df -inul -ibck -ep
-agYYYYMMDDHHMMSS -o+ -ilogE:\scripts\bakzip.log BAK_data%D%*.*
:: 移动到备份文件夹
move E:\scripts\BAK_*.* E:\bak\
:: 执行清理老文件的脚本,只保留10天内文件。
:: 执行格式datedel2_2k3 保留天数清理的文件夹
datedel2_2k3 10 E:\bak\
b)设置windows计划任务每天执行一次bak.cmd。
4、清理老的备份文件的脚本
a)在E:\scripts\下创建文件datedel2_2k3.bat
b)内容:(此脚本适用于windows2003系统)
datedel2_2k3.bat
:: DateDel2.bat - 删除指定路径下指定日数以前修改的文件
:: Will Sort - 2005-9-2 - CMD@WinXP
:: 注意事项:参数%1指定日数,昨天为1,前天为2,依次类推
:: 参数%2指定文件路径,省略时将处理当前路径
:: 核心算法:Ritchie Lawrence, updated 2002-08-13. Version 1.1
::
@echo off & setlocal ENABLEEXTENSIONS
call :Date2Day %date:~0,10% sdays
set /a sdays-=%1
call :Day2Date %sdays% difdate
echo 将删除%cd% 下%difdate% 前的修改的以下文件:
for /r %2 %%f in (*.*) do if "%%~tf" LEQ "%difdate%" del /f /q %%f && echo 删除%%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
c)内容:(此脚本适用于windows2000系统)
:: DateDel2.bat - 删除指定路径下指定日数以前修改的文件
:: Will Sort - 2005-9-2 - CMD@WinXP
:: 注意事项:参数%1指定日数,昨天为1,前天为2,依次类推
:: 参数%2指定文件路径,省略时将处理当前路径
:: 核心算法:Ritchie Lawrence, updated 2002-08-13. Version 1.1
::
@echo off & setlocal ENABLEEXTENSIONS
call :Date2Day %date:~4,10% sdays
set /a sdays-=%1
call :Day2Date %sdays% difdate
echo 将删除%cd% 下%difdate% 前的修改的以下文件:
for /r %2 %%f in (*.*) do if "%%~tf" LEQ "%difdate:~2,14%" del /f /q %%f && echo 删除%%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。