@echo off
chcp 65001
@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 ================================================
set YYYY=%date:~3,4%
set MM=%date:~8,2%
set DD=%date:~11,2%
set HH=%time:~0,2%
set mms=%time:~3,2%
set SS=%time:~6,2%
echo 空格替换未0
set MM=0%MM: =0%
set DD=0%DD: =0%
set HH=0%HH: =0%
set mms=0%mms: =0%
set SS=0%SS: =0%
set MM=%MM:~1,2%
set DD=%DD:~1,2%
set HH=%HH:~1,2%
set mms=%mms:~1,2%
set SS=%SS:~1,2%
echo %YYYY% 年份
echo %MM% 月份
echo %DD% 日
echo 时间
echo %HH% 时
echo %mms% 分
echo %SS% 秒
echo %date%
echo %time%
md G:\oracledatebackup2\%YYYY%%MM%%DD%
echo 正在备份 Oracle 数据库,请稍等……
rem 以下变量需要根据实际情况配置------> 注意:此脚本必须放在BACKUP_DIR目录下
set BACKUP_DIR=G:\oracledatebackup2\%YYYY%%MM%%DD%
set ORACLE_USERNAME=test
set ORACLE_PASSWORD=test
set ORACLE_DB=192.168.1.1/orcl
set BACK_OPTION=full=n
set TODAY=%YYYY%%MM%%DD%%HH%%mms%%SS%
set BACK_NAME=db_%TODAY%
set BACK_FULL_NAME=%BACKUP_DIR%\%BACK_NAME%
echo 文件名 %TODAY%
echo 目录 %BACK_FULL_NAME%
rem 开始备份
exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp log="%BACK_FULL_NAME%.log"
echo 任务完成!