程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> 關於Oracle數據庫 >> Windows系統下Oracle數據庫每天自動備份

Windows系統下Oracle數據庫每天自動備份

編輯:關於Oracle數據庫

linux和unix下面使用shell可以很方便實現,如果windows環境下可以結合計劃任務實現

1.創建備份目錄d:\backup, 創建批處理命令Bak.bat,編寫備份腳本

exp user/passwd@orcl DIRECT=Y BUFFER=100000 FILE=D:\backup\scdd%date:~0,10% OWNER=('scdd') LOG=D:\backup\data.log 
forfiles /p "D:\backup" /s /m *.dmp /d -3 /c "cmd /c del @path"

說明:

exp命令是oracle提供的dump備份命令,其中的%date:~0,10%是DOS裡取日期的命令,例如:C:\Users\qyy>echo %date:~0,10%得到2016-11-30

forfiles是windows的文件查找命令,查找在backup,dmp後綴產生三天的文件,找到後執行刪除操作

2.Windows定時任務每日自動執行批處理文件 3.保留最近三天的文件,自動刪除以前日期的備份文件

forfiles參數說明:

/P 可是搜索的路徑。在我們這裡就是要在哪個目錄尋找要刪除的文件

/M 根據搜索掩碼搜索文件。默認為*,如果要找備份處dump文件,格式為*.dmp

/D 文件修改時間在某個時間之前或者之後。-3 表示3天之前的文件。

/s 包含子目錄

/C 表示為每個文件執行的命令,如果要刪除該文件可以為"cmd /c del /F /s /q @file"。其中變量@file表示該文件名 f s q表示強制靜默刪除可以不用;cmd /c表示執行字符串指定的命令然後終斷

其中@file可以返還如下結果,我們這裡用@path

@file - returns the name of the file.

@fname - returns the file name without extension.

@ext - returns only the extension of the file.

@path - returns the full path of the file.

@relpath - returns the relative path of the file.

@isdir - returns "TRUE" if a file type is a directory, and "FALSE" for files. @fsize - returns the size of the file in bytes.

@fdate - returns the last modified date of the file.

@ftime - returns the last modified time of the file

以上所述是小編給大家介紹的Windows系統下Oracle數據庫每天自動備份,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved