导入导出.bat

rem ===========================================================================
rem Oracle数据库的自动导出备份脚本(windows环境)。
rem 通过windows任务计划 或 AT 命令下自动执行。
rem 作者 秦国辉 2008-9-11
rem ===========================================================================

@echo off
@echo =========================================================================
@echo  windows环境下Oracle数据库的自动备份脚本
@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 备份103服务器 ITSPF 帐号下的数据
REM ======================================================

rem 以下变量需要根据实际情况配置
set BACKUP_DIR=E:/ITSPF_DATABACKUP
set BACKUP_WAREHOUSE=E:/ITSPF_DATABACKUP/BACKUP_WAREHOUSE
set ORACLE_USERNAME=ITSPF
set ORACLE_PASSWORD=PFADMIN
set ORACLE_DB=ITSPFDB
set BACK_OPTION="TABLES=(EVENT_LOG,T_BRIDGE_INFO,T_BRIDGE_LINK_INFO,T_BRIDGE_ROAD,T_CROSS_ADJOIN_UNIT_INFO,T_CROSS_INFO,T_CROSS_LINK_INFO,T_CROSS_ROAD,T_CTROLLER_INFO,T_CTROLLER_SPACE,T_DD_ITEM,T_DD_MAIN,T_DETECTOR_INFO,T_ERROR_LOG,T_EVENT,T_EVENT_HISTORY,T_EVENT_UNIT,T_HIS_EVENT_MID_UNIT,T_INFO_ORDER,T_INFO_SORT,T_INFO_SORT_ORDER,T_LANE_MONTH_DETECT,T_PARK_DAY_IN_OUT,T_PARK_FREE_PLACE,T_PARK_FREE_PLACE_HISTORY,T_PARK_HOUR_IN_OUT,T_PARK_IN_OUT,T_PARK_INFO,T_PARK_ZOOM,T_REGION_INFO,T_REGION_ROAD,T_ROAD_INFO,T_ROLE,T_ROLE_AUTHORITY,T_ROLE_USER,T_SEC_MONTH_DETECT,T_SECTION_INFO,T_SYS_FUNC,T_SYS_LOG,T_SYSTEM_PARA,T_SYSTEM_STATE,T_UNIT_INFO,T_UNIT_MONTH_DETECT,T_UNIT_OWNER,T_USER)"
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 ==================备份103服务器 ITSPF帐号下的数据================= >>%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 ===============备份103服务器 ITSPF帐号下的数据完成!!!============== >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%/*.log %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/
echo .


REM ======================================================
REM 备份103服务器 ITS_ABD 帐号下的数据
REM ======================================================
rem 以下变量需要根据实际情况配置
set BACKUP_DIR=E:/ITSPF_DATABACKUP
set BACKUP_WAREHOUSE=E:/ITSPF_DATABACKUP/BACKUP_WAREHOUSE
set ORACLE_USERNAME=ITS_ABD
set ORACLE_PASSWORD=ABDADMIN
set ORACLE_DB=ITSPFDB
set BACK_OPTION="OWNER=ITS_ABD"
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 ==================备份103服务器 ITS_ABD 帐号下的数据================= >>%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 ===============备份103服务器 ITS_ABD 帐号下的数据完成!!!============== >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%/*.log %BACKUP_WAREHOUSE%/%BACK_NAME%_LOGIC/
echo .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值