windows 下备份数据库脚本

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_34401027/article/details/85235262

rem ---------------------------------------------------------------------------
rem windows环境下Oracle数据库的自动备份脚本。
rem 可以将本批处理设成windows任务计划下自动执行。
@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 以下变量需要根据实际情况配置------> 注意:此脚本必须放在E:\backup目录下
set BACKUP_DIR=D:\oraclebak\epmfdmee
set ORACLE_USERNAME=epmfdmee
set ORACLE_PASSWORD=fcseye
set ORACLE_DB=orcl
set BACK_OPTION= OWNER=epmfdmee
set RAR_CMD="C:\Program Files\WinRAR\Rar.exe"
rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a
set TODAY=%DATE:~0,4%%DATE:~5,2%%DATE:~8,2%%TIME:~0,2%%TIME:~3,2%%TIME:~6,2%
set THISDATETIME=%DATE:~0,4%%DATE:~5,2%%DATE:~8,2%%TIME:~0,2%%TIME:~3,2%%TIME:~6,2%
echo  %THISDATETIME%
set TODAY=2018_12_08
set BACK_NAME=%ORACLE_DB%_%THISDATETIME%_%ORACLE_USERNAME%
set BACK_FULL_NAME=%BACKUP_DIR%\%BACK_NAME%

rem 开始备份
exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@10.200.1.13:1521/%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 /m *.rar -d -7 /c "cmd /c del /f @path"

猜你喜欢

转载自blog.csdn.net/qq_34401027/article/details/85235262