自动备份windows系统下Oracle数据库文件(dmp)

系统上线及后期运维中都免不了给数据库文件备份,windows下的每天凌晨自动备份写成bat文件。

基本sql语句

–1、创建表空间SQL

create tablespace xxtest
logging
datafile 'D:\xxdb_tablespace\xxtest.dbf' 
size 32m 
autoextend on 
next 32m maxsize 2048m
extent management local;

–2、创建用户SQL

create user ceshi
  identified by ceshi
  default tablespace xxtest
  temporary tablespace TEMP;  

–3、给用户赋予权限

grant connect,create any job,unlimited tablespace,resource, dba ,exp_full_database,imp_full_database to ceshi;

–4、导入语句

imp zhengshib/zhengshib@orcl full=y  file=D:\zhengshi_20131009.dmp ignore=y

imp zhengshi/zhengshi@orcl full=y  file=D:\backup\DMP\zhengshib_20131127_092450.DMP ignore=y

–5、导出语句

exp zhengshib/zhengshib@orcl file=D:\zhengshib_20131205.dmp owner=zhengshib

exp grcsp_uat/grcsp_uat@oracle file=D:\grcsp_uat165.dmp owner=grcsp_uat

–6、远程导入\导出

imp  xxtest/xxtest@10.105.182.100:1521/orcl  file=D:\20130731xx_xtt.dmp full=y;
exp  zhengshi/@10.105.182.100:1521/orcl file=d:\xxtest_150_20130804.dmp owner=xxtest

imp  zhengshi/zhengshi@10.105.182.100:1521/orcl file=D:\backup\DMP\zhengshib_20131127_092450.DMP full=y;

bat写法实例

icdb-backup.bat:
  

@echo off
  REM ###########################################################
  REM # Windows Server 2003下Oracle数据库自动备份批处理脚本 add by xm 20160401
  REM ###########################################################
  REM 取当前系统时间,可能因操作系统不同而取值不一样
  set CURDATE=%date:~0,4%%date:~5,2%%date:~8,2%
  set CURTIME=%time:~0,2%
  REM 小时数如果小于10,则在前面补0
  if "%CURTIME%"==" 0" set CURTIME=00
  if "%CURTIME%"==" 1" set CURTIME=01
  if "%CURTIME%"==" 2" set CURTIME=02
  if "%CURTIME%"==" 3" set CURTIME=03
  if "%CURTIME%"==" 4" set CURTIME=04
  if "%CURTIME%"==" 5" set CURTIME=05
  if "%CURTIME%"==" 6" set CURTIME=06
  if "%CURTIME%"==" 7" set CURTIME=07
  if "%CURTIME%"==" 8" set CURTIME=08
  if "%CURTIME%"==" 9" set CURTIME=09
  set CURTIME=%CURTIME%%time:~3,2%%time:~6,2%
  REM 设置所有者、用户名和密码
  set OWNER=xx
  set USER=xx
  set PASSWORD=xx
  set PREFIX=orcl
  REM 创建备份用目录,目录结构为backup/YYYYMMDD/
  REM if not exist "%CURDATE%" mkdir %CURDATE%
  set CURDIR=d:\backup\DMP\
  set FILENAME=%CURDIR%\%OWNER%_%CURDATE%_%CURTIME%.DMP
    set EXPLOG=%CURDIR%\%OWNER%_%CURDATE%_%CURTIME%_log.log
  REM 调用ORACLE的exp命令导出用户数据
    set ORACLE_HOME=D:\oracle\product\10.2.0\db_1
  exp %USER%/%PASSWORD%@%PREFIX% file=%FILENAME% owner=%OWNER%
  exit
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、提供了oracle数据库备份脚本,导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @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 ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值