`
sanyecao2314
  • 浏览: 135267 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

oracle自动备份脚本

 
阅读更多

批处理文件[ 备份.bat] p.s:千万别自作聪明的把此批处理文件命名为exp.bat ,否则……,有兴趣的可以试试。O(∩_∩)O

 

@ echo off

REM ======================================================

REM 备份服务器  rsdlouter帐号下的数据

REM ======================================================

 

 

set BACKUP_DIR=D:\DATABACKUP

set BACKUP_WAREHOUSE=D:\DATABACKUP\DATABACKUP_LOG_DMP

set ORACLE_USERNAME=rsdlouter

set ORACLE_PASSWORD=rsdlouter

set ORACLE_DB=orcl

set BACK_OPTION="TABLES=(LOG,NEWS)"

set RAR_CMD="D:\Program Files\HaoZip\Rar.exe"

 

if not exist "DATABACKUP"             md DATABACKUP

if not exist "DATABACKUP\DATABACKUP_LOG_DMP\"            md DATABACKUP\DATABACKUP_LOG_DMP\

 

for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a

REM 如果文件名中需要小时及分钟,用下面第一行语句

set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_%TODAY%(%time:~0,2%时%time:~3,2%分%time:~6,2%秒)_

REM set BACK_NAME=%ORACLE_DB%_%ORACLE_USERNAME%_%TODAY%

set BACK_FULL_NAME=%BACKUP_DIR%\%BACK_NAME%

 

 

REM 将操作记入批处理日志 %BACK_FULL_NAME%_bat.log

 

echo ==================备份服务器 rsdlouter帐号下的数据================= >>%BACK_FULL_NAME%_bat.log

echo 备份开始...... >>%BACK_FULL_NAME%_bat.log 

echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log

 

 

REM 调用exp工具

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%_DMP  md %BACKUP_WAREHOUSE%\%BACK_NAME%_DMP

 

echo 压缩并删除原有dmp文件...... >>%BACK_FULL_NAME%_bat.log

echo 当前的时间是: %DATE% %time% >>%BACK_FULL_NAME%_bat.log

 

%RAR_CMD% a -df "%BACKUP_DIR%\%BACK_NAME%_dmp.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%_DMP\

 

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 ===============备份服务器 rsdlouter帐号下的数据完成!!!============== >>%BACK_FULL_NAME%_bat.log

 

if not exist %BACKUP_WAREHOUSE%\%BACK_NAME%_LOG md %BACKUP_WAREHOUSE%\%BACK_NAME%_LOG

 

move %BACKUP_DIR%\*.log %BACKUP_WAREHOUSE%\%BACK_NAME%_LOG\

echo .

 

注意:将备份.bat文件放到D盘的根目录下执行,同时请根据情况修改set参数配置。

 

备份.bat配置完成后,利用Windows自带的任务计划即可配置在指定的时间执行此批处理文件了,任务计划配置很简单,在这里就不再赘述了。

 

如果配置任务计划出现异常请参考我的上一篇文章。

 

希望对朋友们有帮助!

分享到:
评论

相关推荐

    Linux oracle 自动备份脚本

    ### Linux Oracle自动备份脚本详解 #### 背景与目的 在企业级数据库管理中,数据的安全性和可靠性至关重要。Oracle作为一款广泛使用的数据库管理系统,其数据备份的重要性不言而喻。通过设置自动化的备份机制可以...

    Oracle自动备份脚本

    通过windows的计划任务,完成Oracle数据的自动备份,利用rar按照系统日期重新命名压缩文件,并通过ftp上传到备份服务器。 具体参见http://blog.csdn.net/z3h/archive/2007/10/05/1812063.aspx 20080125补充一下:...

    oracle自动备份脚本的

    本文将围绕“Oracle自动备份脚本”这一主题,详细讲解如何利用脚本来实现Oracle数据库的定时备份。 首先,我们要理解标题中的“Oracle自动备份脚本”。这通常指的是一个批处理脚本,它包含了执行Oracle数据库备份的...

    windows环境下Oracle数据库的自动备份脚本

    windows环境下Oracle数据库的自动备份脚本

    linux 下的 oracle 自动备份脚本

    linux 下的 oracle 自动备份脚本

    oracle数据库自动备份脚本

    对于生产环境,通常需要对数据库执行有定时备份操作,好方便数据库出现异常问题的数据恢复,提高数据库的安全性,这里提供linux服务器下详细操作脚本,供大家参阅

    ORACLE自动备份脚本

    用于ORACLE自动备份用,必须先安装7Z压缩软件才能使用。

    oracle 数据库自动备份脚本

    实现oracle 数据库自动备份+保留最新的7天数据+另一机器拷贝备份的脚本

    Oracle数据库自动备份脚本FOR WIN.rar

    "Oracle数据库自动备份脚本FOR WIN.rar" 是一个针对Windows环境设计的自动化备份解决方案,它使得Oracle数据库的备份过程更加简便和可靠。 这个脚本主要有以下三个特点: 1. **动态日期命名**:备份导出文件时,...

    Oracle数据库RMAN的自动备份脚本

    ### Oracle数据库RMAN的自动备份脚本知识点解析 在企业级数据库管理中,备份与恢复是确保数据安全的重要环节之一。本文将详细解读一个Oracle数据库RMAN(Recovery Manager)的自动备份脚本,该脚本适用于Linux环境...

    oracle数据库自动备份脚本带说明

    "oracle数据库自动备份脚本带说明"的标题表明这是一个关于如何自动化执行Oracle数据库备份的脚本,这对于系统管理员来说是非常实用的工具。下面我们将详细探讨Oracle数据库的备份策略、自动备份脚本的工作原理以及...

Global site tag (gtag.js) - Google Analytics