很多時候我們需要自動備份數據庫這邊推薦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 任務完成!
