Oracle 数据自动备份 通过EXP备份

先写个批处理文件(.bat),具体如下:
@echo off
@echo ================================================
@echo  windows环境下Oracle数据库的自动备份脚本
@echo  说明:启动备份时,需要配置以下变量
@echo    1、BACKUP_DIR           指定要备份到哪个目录
@echo    2、ORACLE_USERNAME      指定备份所用的Oracle用户名
@echo    3、ORACLE_PASSWORD      指定备份所用的Oracle密码
@echo    4、ORACLE_DB            指定备份所用的Oracle连接名
@echo    5、BACK_OPTION          备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户  等等....
@echo    6、RAR_CMD              指定RAR命令行压缩工具所在目录
@echo ================================================

rem 以下变量需要根据实际情况配置
set BACKUP_DIR=D:/jboss-dljy/database_bak
set ORACLE_USERNAME=ccpgjyzx
set ORACLE_PASSWORD=jyzx1hdkj
set ORACLE_DB=ccpgyx_10.224.15.139
set BACK_OPTION=owner=ccpgjyzx
set RAR_CMD="C:/Progra~1/WinRAR/Rar.exe"

for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a
set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_
set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME%

rem 开始备份
exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB%  %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log"
rem 压缩并删除原有文件
%RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log"

rem 删除七天前的备份文件
forfiles /p D:/jboss-dljy/database_bak /s /m *.rar /d -7 /c "cmd /c del @file

posted @ 2014-03-16 22:20  学习札记  阅读(1980)  评论(0编辑  收藏  举报