`
desert3
  • 浏览: 2141011 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

(转)Oracle数据库的自动导出备份脚本(windows环境)

阅读更多
转自Oracle数据库的自动导出备份脚本(windows环境)
由于winrar收费,修改了下脚本使用7zip进行压缩处理
@echo off
@echo ===========================================================================
@echo Oracle数据库的自动导出备份脚本(windows环境)。
@echo 通过windows任务计划 或 AT 命令设置自动执行。
@echo ===========================================================================

@echo =========================================================================
@echo Oracle数据库的自动导出备份脚本(windows环境)。
@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    8、ZIP_CMD             指定7ZIP命令行压缩工具所在目录(开源免费) 
@echo =========================================================================

@echo ======================================================
@echo 备份数据库服务数据
@echo ======================================================

rem 以下变量需要根据实际情况配置
set BACKUP_DIR=D:\proj\dbbackup
set BACKUP_WAREHOUSE=D:\proj\dbbackup\file
set ORACLE_USERNAME=user
set ORACLE_PASSWORD=pwd
set ORACLE_DB=tnsname
set BACK_OPTION="owner=user"
set RAR_CMD="C:\Program Files (x86)\WinRAR\WinRAR.exe"
set ZIP_CMD="C:\Program Files (x86)\7-Zip\7z.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

REM 使用7ZIP压缩,注释掉WINRAR命令部分
REM %RAR_CMD% a -df "%BACK_NAME%_logic.rar" "%BACK_FULL_NAME%.dmp"
%ZIP_CMD% a -tzip "%BACK_NAME%_logic.zip" "%BACK_FULL_NAME%.dmp"
rem 删除源文件
del "%BACK_FULL_NAME%.dmp"

echo "%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

rem 使用7ZIP压缩,注释掉WINRAR命令部分
rem move %BACKUP_DIR%\*.rar %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC\
move %BACKUP_DIR%\*.zip %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 ===============备份数据库服务数据完成!!!============== >>%BACK_FULL_NAME%_bat.log
move %BACKUP_DIR%\*.log %BACKUP_WAREHOUSE%\%BACK_NAME%_LOGIC\
echo .
分享到:
评论

相关推荐

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

    软件介绍: windows环境下Oracle数据库的自动备份脚本 1、备份导出文件时自动使用当前日期进行命名2、自动压缩备份文件3、自动删除7天前的备份

    oracle数据库定期备份导出dmp文件的脚本和定时任务的设置.zip

    @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_...

    oracle数据库数据泵自动备份脚本

    linux下oracle数据泵备份完美解决了数据备份的完整性,这里提供大家数据泵自动备份的脚本,为各类生产环境中的数据的备份提供的较完善的解决方案

    定时导出Oracle数据库数据并上传到FTP目录脚本

    编写一个bat脚本实现从Oracle数据库定时导出指定数据表的指定字段为txt文本并上传到FTP服务器的指定目录

    sql+oracle 数据库脚本备份及重要表数据批量导出

    4、自动解析oracle连接配置,支持不安装sqlplus备份oracle中某个用户的所有对象脚本,方便备份。 5.能够批量导出oracle用户下的重要的小表数据。 6.如果有用户下载此软件,可以通过QQ : 8767452 索取注册码。

    oracle数据库导出导入脚本

    用于导入导出oracle数据库的脚本,直接下来,配置用户名密码以及数据库名,备份的文件名等双击即可执行。

    oracle数据库对象备份与恢复脚本工具

    根据某个数据库迁移项目需要,结合个人对数据库对象的理解,整理了一份数据库对象(包括表、视图)导出、导入脚本。供参考。 1、实现存储过程、函数、包、触发器、视图、同义词的批量导出与恢复脚本 2、以下脚本均在...

    WINDOWS系统下ORACLE数据库定时自动备份

    为避免数据丢失或错误,对数据库数据的定时备份。oracle导出脚本 及windows 任务 设置的说明文档

    数据库导入导出命令脚本

    用于oracle数据库中表的导入和导出,方便于对数据库的备份

    oracle备份脚本-Windows.rar

    oralce 备份脚本,适用于windows, 里面包含oracle expdp, rman备份。经过多少生产环境验证。

    高性能动态SQL Oracle数据安全 Oracle 数据库的聚簇技术 等等

    用Windows脚本宿主自动化Oracle工具 31 进程结构和内存结构 32 Oracle监控数据库性能的SQL汇总 36 Oracle如何精确计算row的大小 38 PL/SQL编程 39 数据库的分组问题 41 oracle知识 42 数据库的导入导出 42 Oracle...

    linux下shell脚本实现数据的导出

    第一次接触linux系统,之前写的数据导出不好使了。原因是程序放在root用户下,要runtime执行exp的话,root不认exp命令;找了好多资料,最后决定写个shell脚本;没接触过shell脚本,网上...只是最简单的数据表的导出备份

    oracle自动备份脚本的

    因为前边那个文件使用的脚本的调用,通过测试发现脚本里面有操作(复制删除)和导出时,定时计划不执行,故分成两个定时计划设置如附件

    oracle数据库备份

    Oracle数据库的备份方法很多,无论使用那种备份方法,备份的目的都是为了在出现故障后能够以尽可能小的时间和代价恢复系统。比如使用export实用程序导出数据库对象、使用Oracle备份数据库、使用Oracle对称复制、使用...

    Oracle数据库在Windows2008中的自动备份脚本及配置说明

    内有expdp和exp两种导出方式的编码及设置说明。图文并茂,实机测试通过。原创作品!

    Oracle数据库管理员技术指南

    备用数据库(仅 Windows NT 平台有效) 6.14.3 利用热备用数据库与远程镜像 6.15 回顾 第7章 备份和恢复技术 7.1 备份选项 7.2 操作系统备份 7.2.1 冷备份 7.2.2 OFA 和备份 7.2.3 热备份 7.2.4 使备份...

    Oralce备份脚本exp命令

    利用oralce系统中的exp命令来实现数据库的导出,通过计划任务方式实现定期作业管理备份数据库

    oracle备份

    Oracle数据库的备份方法很多,无论使用那种备份方法,备份的目的都是为了在出现故障后能够以尽可能小的时间和代价恢复系统。比如使用export实用程序导出数据库对象、使用Oracle备份数据库、使用Oracle对称复制、使用...

    oracle创建数据库脚本

    定时导出导入备份数据库 博文链接:https://jxpengtao.iteye.com/blog/178163

Global site tag (gtag.js) - Google Analytics