自动备份数据库

1.首先建一个批处理文件,文件的内容如下,根据实际环境进行修改。


@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=E:\database_bak
set ORACLE_USERNAME=ccpgdljy
set ORACLE_PASSWORD=ccpgdljy
set ORACLE_DB=jtmis_192.168.99.231
set BACK_OPTION=
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"

2.将写好的批处理文件加入到计划任务中,设定计划任务的执行时间为每天某个固定的时间。



如:


set BACKUP_DIR=E:\test
set ORACLE_USERNAME=svn
set ORACLE_PASSWORD=svn
set ORACLE_DB=orcl
set BACK_OPTION=
set RAR_CMD="C:\Program Files\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%

exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log"
%RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log"



任务计划错误的解决办法:
错误代码: 0x80041315 ,产生这个错误的原因一般都是 Task Scheduler 服务被禁用了的原因!
解决方法:开始--运行 输入 services.msc 回车 把 Task Scheduler 服务设置成自动 或者手动 然后起用就可以了!




在bat最后一行加上

echo. & pause


就会等键盘输入才会退出窗口。

相关文档
最新文档