Oracle自動備份bat


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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM