標籤:windows下oracle資料庫每天自動備份一次 windows下oracle資料庫bat指令碼
1、根據日期自動產生 Oracle 備份檔案
@echo off
echo 正在備份Oracle資料庫,請稍等......
exp userid=‘使用者名稱/密碼@SID‘ file=D:\bak\res_%date:~0,4%%date:~5,2%%date:~8,2%.dmp log=D:\bak\res_%date:~0,4%%date:~5,2%%date:~8,2%.log owner=res
echo 任務完成!
2、根據日期時間分秒自動產生 Oracle 備份檔案
@echo off
echo 正在備份Oracle資料庫,請稍等......
exp userid=‘使用者名稱/密碼@SID‘ file=D:\bak\res_%date:~0,4%%date:~5,2%%date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2%.dmp log=D:\bak\res_%date:~0,4%%date:~5,2%%date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2%.log
echo 任務完成!
3、用exit結尾備份完後自動結束:
@echo off
echo ================================================
echo Windows環境下Oracle資料庫的自動備份指令碼
echo 1. 使用當前日期命名備份檔案。
echo 2. 自動刪除7天前的備份。
echo ================================================
::以“YYYYMMDD”格式取出目前時間。
set BACKUPDATE=%date:~0,4%%date:~5,2%%date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2%
::建立備份目錄。
if not exist "D:\backup\data" mkdir D:\backup\data
if not exist "D:\backup\log" mkdir D:\backup\log
set DATADIR=D:\backup\data
set LOGDIR=D:\backup\log
exp userid=‘使用者名稱/密碼@SID‘ file=%DATADIR%\data_%BACKUPDATE%.dmp log=%LOGDIR%\log_%BACKUPDATE%.log
::刪除7天前的備份。
forfiles /p "%DATADIR%" /s /m *.* /d -7 /c "cmd /c del @path"
forfiles /p "%LOGDIR%" /s /m *.* /d -7 /c "cmd /c del @path"
exit
註:如果有時我們寫bat指令碼執行時一閃而過,無法排錯;那麼我可以在指令碼的最後加個pause(如上面的指令碼可以把exit換成pause),用pause結尾執行完後,會提示按任意鍵來繼續或退出,這樣我就能知道是什麼報錯。
本文出自 “營運筆錄 美玲” 部落格,請務必保留此出處http://meiling.blog.51cto.com/6220221/1573848
windows下oracle資料庫自動備份指令碼