Oracle自动备份bat

本文介绍使用批处理脚本和Windows计划任务实现Oracle数据库自动备份的方法。包括设置备份目录、用户名、密码等变量,以及使用exp命令进行备份,并提供清理旧备份文件的脚本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

很多时候我们需要自动备份数据库这边推荐bat+Windows计划任务实现

方案1 创建以下bat 然后添加到TaskSchedule(路径最好不要包含中文)

@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 ================================================ 

    echo 正在备份 Oracle 数据库,请稍等……    

    rem 以下变量需要根据实际情况配置------> 注意:此脚本必须放在BACKUP_DIR目录下 
    set BACKUP_DIR=C:\Users\Simon\Desktop\back
    set ORACLE_USERNAME=CSJJ
    set ORACLE_PASSWORD=CSJJ_BASIC
    set ORACLE_DB=172.16.9.119/orcl
    set BACK_OPTION=owner=CSJJ
     
    set TODAY=%date:~0,4%%date:~5,2%%date:~8,2%_%time:~0,2%%time:~3,2%
    set BACK_NAME=%ORACLE_USERNAME%_%TODAY%
    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%.log" 
    
    echo 任务完成!

 方案2. 同样是bat 可以同时备份多个

@echo off

echo 删除30天前的备分文件和日志

 

forfiles /p "D:\ORACLEBACKUP\bak" /m *.dmp /d -30 /c "cmd /c del @path"

forfiles /p "D:\ORACLEBACKUP\bak" /m *.log /d -30 /c "cmd /c del @path"

 

echo 正在备份 Oracle 数据库,请稍等……

exp user1/pwd@x.xx.250.89/ORCL file=D:\ORACLEBACKUP\bak\user1%date:~0,4%%date:~5,2%%date:~8,2%.dmp  log=D:\ORACLEBACKUP\bak\user1%date:~0,4%%date:~5,2%%date:~8,2%.log  owner=user1  buffer=65535
exp user2/pwd@x.xx.250.89/ORCL file=D:\ORACLEBACKUP\bak\user2%date:~0,4%%date:~5,2%%date:~8,2%.dmp  log=D:\ORACLEBACKUP\bak\user2%date:~0,4%%date:~5,2%%date:~8,2%.log  owner=user1  buffer=65535
exp user3/pwd@x.xx.250.89/ORCL file=D:\ORACLEBACKUP\bak\user3%date:~0,4%%date:~5,2%%date:~8,2%.dmp  log=D:\ORACLEBACKUP\bak\user3%date:~0,4%%date:~5,2%%date:~8,2%.log  owner=user3  buffer=65535
...
echo 任务完成!

 

转载于:https://www.cnblogs.com/yangsirc/p/11101696.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值