很多时候我们需要自动备份数据库这边推荐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:UsersSimonDesktopback 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:ORACLEBACKUPak" /m *.dmp /d -30 /c "cmd /c del @path" forfiles /p "D:ORACLEBACKUPak" /m *.log /d -30 /c "cmd /c del @path" echo 正在备份 Oracle 数据库,请稍等…… exp user1/pwd@x.xx.250.89/ORCL file=D:ORACLEBACKUPakuser1%date:~0,4%%date:~5,2%%date:~8,2%.dmp log=D:ORACLEBACKUPakuser1%date:~0,4%%date:~5,2%%date:~8,2%.log owner=user1 buffer=65535 exp user2/pwd@x.xx.250.89/ORCL file=D:ORACLEBACKUPakuser2%date:~0,4%%date:~5,2%%date:~8,2%.dmp log=D:ORACLEBACKUPakuser2%date:~0,4%%date:~5,2%%date:~8,2%.log owner=user1 buffer=65535 exp user3/pwd@x.xx.250.89/ORCL file=D:ORACLEBACKUPakuser3%date:~0,4%%date:~5,2%%date:~8,2%.dmp log=D:ORACLEBACKUPakuser3%date:~0,4%%date:~5,2%%date:~8,2%.log owner=user3 buffer=65535 ... echo 任务完成!