Oracle数据库的自动导出备份脚本(windows环境)
2014-03-28 18:18
543 查看
脚本如下:
rem ===========================================================================
rem 通过windows任务计划 或 AT 命令设置自动执行。
rem ===========================================================================
@echo off
@echo =========================================================================
@echo 说明:启动备份时,需要配置以下变量
@echo 1、BACKUP_DIR 指定要备份到哪个中间目录,压缩完成后将被移动到BACKUP_WAREHOUSE目录下
@echo 2、BACKUP_WAREHOUSE 指定历史备份数据(压缩后的)及日志的存放位置
@echo 3、ORACLE_USERNAME 指定备份所用的Oracle用户名
@echo 4、ORACLE_PASSWORD 指定备份所用的Oracle密码
@echo 5、ORACLE_DB 指定备份所用的Oracle服务名
@echo 6、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 或 TABLES=() 等等....
@echo 7、RAR_CMD 指定RAR命令行压缩工具所在目录
@echo =========================================================================
REM ======================================================
REM 备份服务器 test帐号下的数据
REM ======================================================
rem 以下变量需要根据实际情况配置
set BACKUP_DIR=D:\DATABACKUP\
set BACKUP_WAREHOUSE=D:\DATABACKUP\BACKUP_WAREHOUSE\
set ORACLE_USERNAME=test
set ORACLE_PASSWORD=test
set ORACLE_DB=
set BACK_OPTION="owner=test"
set RAR_CMD="C:\Program Files\WinRAR\Rar.exe"
for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a
REM 如果文件名中需要小时及分钟,用下面第一行语句
REM set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_
set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_%TODAY%
set BACK_FULL_NAME=%BACKUP_DIR%\%BACK_NAME%
REM 将操作记入批处理日志 %BACK_FULL_NAME%_bat.log
echo ==================备份服务器帐号下的数据================= >>%BACK_FULL_NAME%_bat.log
echo 备份开始...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% grants=Y %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%_exp.log"
if not exist %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC (md %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC)
echo 压缩并删除原有dmp文件...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
%RAR_CMD% a -df "%BACK_NAME%_logic.rar" "%BACK_FULL_NAME%.dmp"
REM "%BACK_FULL_NAME%exp.log"
echo 压缩并删除原有dmp文件结束! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
echo 开始移动文件...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%\*.rar %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC\
echo 移动文件完成! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
REM net send %userdomain% "数据库逻辑备份已于:%DATE% %time% 完成!"
echo .
echo 备份完成!!! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
echo ===============备份服务器 TEST帐号下的数据完成!!!============== >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%\*.log %BACKUP_WAREHOUSE%\%BACK_NAME%_CLOGIC\
echo .
转载自:http://blog.itpub.net/12330444/viewspace-445582/
rem ===========================================================================
rem 通过windows任务计划 或 AT 命令设置自动执行。
rem ===========================================================================
@echo off
@echo =========================================================================
@echo 说明:启动备份时,需要配置以下变量
@echo 1、BACKUP_DIR 指定要备份到哪个中间目录,压缩完成后将被移动到BACKUP_WAREHOUSE目录下
@echo 2、BACKUP_WAREHOUSE 指定历史备份数据(压缩后的)及日志的存放位置
@echo 3、ORACLE_USERNAME 指定备份所用的Oracle用户名
@echo 4、ORACLE_PASSWORD 指定备份所用的Oracle密码
@echo 5、ORACLE_DB 指定备份所用的Oracle服务名
@echo 6、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 或 TABLES=() 等等....
@echo 7、RAR_CMD 指定RAR命令行压缩工具所在目录
@echo =========================================================================
REM ======================================================
REM 备份服务器 test帐号下的数据
REM ======================================================
rem 以下变量需要根据实际情况配置
set BACKUP_DIR=D:\DATABACKUP\
set BACKUP_WAREHOUSE=D:\DATABACKUP\BACKUP_WAREHOUSE\
set ORACLE_USERNAME=test
set ORACLE_PASSWORD=test
set ORACLE_DB=
set BACK_OPTION="owner=test"
set RAR_CMD="C:\Program Files\WinRAR\Rar.exe"
for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a
REM 如果文件名中需要小时及分钟,用下面第一行语句
REM set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_
set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_%TODAY%
set BACK_FULL_NAME=%BACKUP_DIR%\%BACK_NAME%
REM 将操作记入批处理日志 %BACK_FULL_NAME%_bat.log
echo ==================备份服务器帐号下的数据================= >>%BACK_FULL_NAME%_bat.log
echo 备份开始...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% grants=Y %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%_exp.log"
if not exist %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC (md %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC)
echo 压缩并删除原有dmp文件...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
%RAR_CMD% a -df "%BACK_NAME%_logic.rar" "%BACK_FULL_NAME%.dmp"
REM "%BACK_FULL_NAME%exp.log"
echo 压缩并删除原有dmp文件结束! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
echo 开始移动文件...... >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%\*.rar %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC\
echo 移动文件完成! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
REM net send %userdomain% "数据库逻辑备份已于:%DATE% %time% 完成!"
echo .
echo 备份完成!!! >>%BACK_FULL_NAME%_bat.log
echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log
echo ===============备份服务器 TEST帐号下的数据完成!!!============== >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%\*.log %BACKUP_WAREHOUSE%\%BACK_NAME%_CLOGIC\
echo .
转载自:http://blog.itpub.net/12330444/viewspace-445582/
相关文章推荐
- (转)Oracle数据库的自动导出备份脚本(windows环境)
- (转)Oracle数据库的自动导出备份脚本(windows环境)
- Windows环境下Oracle数据库的自动备份脚本
- Windows环境下Oracle数据库的自动备份脚本
- Windows环境下Oracle数据库的自动备份脚本
- 【Windows】Windows环境下Oracle数据库的自动备份脚本
- windows环境下Oracle数据库的自动备份脚本
- windows环境下配置MySQL数据库自动备份脚本
- Windows下Oracle数据库自动备份批处理脚本
- windows下oracle数据库的exp自动备份脚本
- Oracle数据库在Windows环境下导出并定时备份
- Oracle数据库Windows 2003环境自动备份批处理
- windows下oracle数据库自动备份脚本
- 生产环境Mysql数据库备份脚本,Linux下网站数据定期自动备份与删除脚本,Windows下备份网站目录和数据库
- windows上自动设置java环境变量的脚本
- Oracle数据库定时自动备份批处理代码(Windows)
- Windows Server 2003下Oracle数据库自动备份批处理脚本
- windows下expdp自动备份脚本
- 在Windows环境下使用MySQL:自动定时备份
- windows脚本解决SQL SERVER自动备份问题