(转)Oracle数据库的自动导出备份脚本(windows环境)

  1. 转自Oracle数据库的自动导出备份脚本(windows环境)
    由于winrar收费,修改了下脚本使用7zip进行压缩处理
  2. @echo off  
  3. @echo ===========================================================================   
  4. @echo Oracle数据库的自动导出备份脚本(windows环境)。   
  5. @echo 通过windows任务计划 或 AT 命令设置自动执行。   
  6. @echo ===========================================================================   
  7.   
  8. @echo =========================================================================   
  9. @echo Oracle数据库的自动导出备份脚本(windows环境)。   
  10. @echo  说明:启动备份时,需要配置以下变量   
  11. @echo    1、BACKUP_DIR           指定要备份到哪个中间目录,压缩完成后将被移动到BACKUP_WAREHOUSE目录下   
  12. @echo    2、BACKUP_WAREHOUSE     指定历史备份数据(压缩后的)及日志的存放位置   
  13. @echo    3、ORACLE_USERNAME      指定备份所用的Oracle用户名   
  14. @echo    4、ORACLE_PASSWORD      指定备份所用的Oracle密码   
  15. @echo    5、ORACLE_DB            指定备份所用的Oracle服务名   
  16. @echo    6、BACK_OPTION          备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 或 TABLES=() 等等....   
  17. @echo    7、RAR_CMD              指定RAR命令行压缩工具所在目录   
  18. @echo    8、ZIP_CMD             指定7ZIP命令行压缩工具所在目录(开源免费)    
  19. @echo =========================================================================   
  20.   
  21. @echo ======================================================   
  22. @echo 备份数据库服务数据   
  23. @echo ======================================================   
  24.   
  25. rem 以下变量需要根据实际情况配置   
  26. set BACKUP_DIR=D:/proj/dbbackup   
  27. set BACKUP_WAREHOUSE=D:/proj/dbbackup/file   
  28. set ORACLE_USERNAME=user  
  29. set ORACLE_PASSWORD=pwd   
  30. set ORACLE_DB=tnsname   
  31. set BACK_OPTION="owner=user"  
  32. set RAR_CMD="C:/Program Files (x86)/WinRAR/WinRAR.exe"  
  33. set ZIP_CMD="C:/Program Files (x86)/7-Zip/7z.exe"  
  34.   
  35. for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a   
  36. REM 如果文件名中需要小时及分钟,用下面第一行语句   
  37. REM set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_   
  38. set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_%TODAY%   
  39. set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME%   
  40.   
  41.   
  42. REM 将操作记入批处理日志 %BACK_FULL_NAME%_bat.log   
  43.   
  44. echo ==================备份数据库服务数据================= >>%BACK_FULL_NAME%_bat.log   
  45. echo 备份开始...... >>%BACK_FULL_NAME%_bat.log   
  46. echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  47.   
  48.   
  49. exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% grants=Y %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%_exp.log"  
  50.   
  51.   
  52. if not exist %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC (md %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC)   
  53.   
  54. echo 压缩并删除原有dmp文件...... >>%BACK_FULL_NAME%_bat.log   
  55. echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  56.   
  57. REM 使用7ZIP压缩,注释掉WINRAR命令部分   
  58. REM %RAR_CMD% a -df "%BACK_NAME%_logic.rar" "%BACK_FULL_NAME%.dmp"  
  59. %ZIP_CMD% a -tzip "%BACK_NAME%_logic.zip" "%BACK_FULL_NAME%.dmp"  
  60. rem 删除源文件   
  61. del "%BACK_FULL_NAME%.dmp"  
  62.   
  63. echo "%BACK_FULL_NAME%exp.log"  
  64. echo 压缩并删除原有dmp文件结束! >>%BACK_FULL_NAME%_bat.log   
  65. echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  66.   
  67. echo 开始移动文件...... >>%BACK_FULL_NAME%_bat.log   
  68. echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  69.   
  70. rem 使用7ZIP压缩,注释掉WINRAR命令部分   
  71. rem move %BACKUP_DIR%/*.rar %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/   
  72. move %BACKUP_DIR%/*.zip %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/   
  73.   
  74. echo 移动文件完成! >>%BACK_FULL_NAME%_bat.log   
  75. echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  76.   
  77. REM net send %userdomain% "数据库逻辑备份已于:%DATE% %time% 完成!"  
  78.   
  79. echo .   
  80. echo 备份完成!!! >>%BACK_FULL_NAME%_bat.log   
  81. echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log   
  82. echo ===============备份数据库服务数据完成!!!============== >>%BACK_FULL_NAME%_bat.log   
  83. move %BACKUP_DIR%/*.log %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/   
  84. echo .  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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"

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值