oracle数据库的定时备份:导出 压缩 归类

本文介绍了一种通过批处理脚本实现的自动数据库备份方法,包括定时导出数据库、自动压缩备份文件及按月归档的功能。该方案适用于需要定期进行数据库备份的企业环境。

http://skzr-org.javaeye.com/blog/811491

 

 

目标:

  1. 定时导出:利用计划任务
  2. 自动压缩:使用命令行的rar
  3. 自动按月存储:利用cmd

 

代码:

 

Cmd代码 复制代码
  1. @echo 一定要进入指定路径,否则运行不正常   
  2. @set bk_path=G:/Database_bak   
  3. @set rar_path=d:/WinRAR   
  4. @set owner=erp_beijing_exp   
  5. @set userid=%owner%/erp_beijing_exp@dbsvr   
  6. @echo on   
  7. @CLS   
  8. @echo 欢迎使用自动导库程序   
  9. @echo 开始执行   
  10. @echo 进入目录: %bk_path%   
  11. @%bk_path:~0,2%   
  12. @cd %bk_path%   
  13. cd   
  14. set THE_MONTH=%DATE:~0,4%-%DATE:~5,2%   
  15. set THE_DATE=%THE_MONTH%-%DATE:~8,2%   
  16. echo %THE_DATE%   
  17. set MY_HOUR=%time:~0,2%   
  18. if "%time:~0,1%"==" " set MY_HOUR=0%time:~1,1%   
  19.   
  20. SET MY_DATE=%THE_DATE%_%MY_HOUR%-%TIME:~3,2%-%TIME:~6,2%   
  21. @echo 当前时间%THE_DATE%   
  22. @set filename=%MY_DATE%_%username%   
  23. exp.exe userid="%userid%" owner=%owner% file=%filename%.dmp log=%filename%-exp.log   
  24. "%rar_path%/rar" a -k -t -s -m5 -mc63:128t+ -mdg -df %filename%.rar %filename%*.*   
  25. MKDIR %bk_path%/%THE_MONTH%   
  26. MOVE %bk_path%/*%THE_DATE%*.* %bk_path%/%THE_MONTH%   
  27. exit  

 

 

遇到的问题和解决:

 

  1. 文件名中:小时在10点之前为“ X”有个空格导致文件名出问题,解决set MY_HOUR=%time:~0,2%
    Cmd代码 复制代码
    1. if "%time:~0,1%"==" " set MY_HOUR=0%time:~1,1%  
     
1、提供了oracle数据库备份脚本导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @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:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,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 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值