設(shè)置SQLServer2008自動壓縮備份數(shù)據(jù)庫_第1頁
設(shè)置SQLServer2008自動壓縮備份數(shù)據(jù)庫_第2頁
設(shè)置SQLServer2008自動壓縮備份數(shù)據(jù)庫_第3頁
設(shè)置SQLServer2008自動壓縮備份數(shù)據(jù)庫_第4頁
設(shè)置SQLServer2008自動壓縮備份數(shù)據(jù)庫_第5頁
已閱讀5頁,還剩2頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、我們通常在維護數(shù)據(jù)庫的時候,都會建立一個備份的機制,在SQL Server中, 我們就可以通過如下的方法來實現(xiàn):如果SQL Server代理沒有啟動,我們先把其啟動,然后新建立一個作業(yè), 名稱命名為“MyDb全備份,在分類下面選擇“數(shù)據(jù)庫維護,然后新建立 作業(yè)第一個步驟,步驟名為“對數(shù)據(jù)進行完全備份,然后在命令框中輸入如下 的SQL代碼:DECLARE strSql VARCHAR(1000),strSqlCmd VARCHAR(1000),timeDateDiff INTSET timeDateDiff = DATEDIFF(week,0,GETDATE()-1900-01-0T, Here

2、 0 standsfor1900-01-01,SET timeDateDiff = CASE DATEPART(WEEKDAY,GETDATE()WHEN 1 THEN timeDateDiff -1ELSE timeDateDiff ENDSET strSql=D:DataBaseBackDataMyDb_-備份目錄及備份的文件頭,目錄必須存在+CONVERT(CHAR(8),DATEADD(week, timeDateDiff,0),112)-完全備份日期+_0100-完全備份時間+完全備份SET strSqlCmd= strSql+.BAK-備份文件的擴展名BACKUP DATABASE

3、 MyDbTO DISK = strSqlCmd WITH INIT,NOUNLOAD,NAME = NMyDb備份,NOSKIP,STATS = 10,NOFORMAT操作如圖一:圖一建立作業(yè)對數(shù)據(jù)庫進行完全備份然后開始執(zhí)行對數(shù)據(jù)庫的壓縮,在步驟中再新建一個作業(yè),步驟名為“壓縮數(shù)據(jù) 庫,然后在命令框中輸入如下的SQL代碼:DECLARE strSql VARCHAR(1000),strSqlCmd VARCHAR(1000),timeDateDiff INT,strWeekDay VARCHAR(20)SET timeDateDiff= DATEDIFF(week,0,GETDATE()SE

4、T timeDateDiff= CASE DATEPART(WEEKDAY,GETDATE()WHEN 1 THEN timeDateDiff-1ELSE timeDateDiff ENDSET strSql=D:DataBaseBackDataMyDb_-備份目錄及備份的文件頭+CONVERT(CHAR(8),DATEADD(week,timeDateDiff,0),112)-完全備份日期+_0100-完全備份時間+完全備份SET strWeekDay= CASE DATEPART(WEEKDAY,GETDATE() WHEN 1星HEN WHEN 2 THEN星期一WHEN 3 THEN星

5、期二WHEN 4 THEN星期三WHEN 5 THEN星期四WHEN 6 THEN星期五WHEN 7 THEN星期六ENDSET strSqlCmd= ECHO壓縮開始日期: +CONVERT(VARCHAR(20),GETDATE(),120)+strWeekDay+ D:DataBaseBackDataCompressDataBaseMyDb_+CONVERT(CHAR(6),DATEADD(week,timeDateDiff,0),112)+.txtEXEC master.dbo.XP_CMDSHELL strSqlCmd,NO_OUTPUTSET strSqlCmd= RAR.EXE

6、A -R +strSql+.RAR +strSql+.BAK D:DataBaseBackDataCompressDataBaseMyDb_+CONVERT(CHAR(6),DATEADD(week,timeDateDiff,0),112)+.txtPRINT LEN(strSqlCmd)PRINT (strSqlCmd)EXEC master.dbo.XP_CMDSHELL strSqlCmd,NO_OUTPUTSETstrSqlCmd=ECHO壓縮日期:+CONVERT(VARCHAR(20),GETDATE(),120)+strWeekDay+ D:DataBaseBackDataCom

7、pressDataBaseMyDb_+CONVERT(CHAR(6),DATEADD(week,timeDateDiff,0),112)+.txtEXEC master.dbo.XP_CMDSHELL strSqlCmd,NO_OUTPUT操作如圖二:圖二建立作業(yè)對數(shù)據(jù)進行壓縮完成后我們可以看到操作步驟的對話框,如圖三:蠟性-(local)| 琦定 | 職洎 |圖三 數(shù)據(jù)完全備份的步驟我們對照上圖,注意兩點,第一個是步驟1“成功時這一列的顯示,當成 功的時候轉(zhuǎn)到下一步,“失敗時當失敗的時候失敗后退出,步驟2“成功時 當成功的時候成功后退出,“失敗時當失敗時失敗后退出。確保兩個步驟對數(shù) 據(jù)操作的

8、正常。再執(zhí)行“調(diào)度 一欄,主要實現(xiàn)在什么時候執(zhí)行這些作業(yè),我們定在每周日 一點的時候開始執(zhí)行,如圖四:圖四建立調(diào)度這樣就可以建立好對數(shù)據(jù)庫的整個完全備份了。有時我們數(shù)據(jù)在遭到破壞的時候,而在恢復(fù)到上次的整個備份時,就會產(chǎn)生 很多喪失的數(shù)據(jù)了,這時我們就必須還得建立另外一種備份的機制一差異備份。步驟還和上面一樣,我們建立一個作業(yè),命名為“MyDt異備份,在步 驟里面同樣是建立兩個步驟,分別是差異備份和差異壓縮,步驟一在命令框中輸 入內(nèi)容如下:DECLARE strSql VARCHAR(1000),strSqlCmd VARCHAR(1000),timeDateDiff INTSET timeD

9、ateDiff = DATEDIFF(week,0,GETDATE()SET timeDateDiff = CASE DATEPART(WEEKDAY,GETDATE()WHEN 1 THEN timeDateDiff -1ELSE timeDateDiff ENDSET strSql=D:DataBaseBackDataMyDb_-備份目錄及備份的文件頭+CONVERT(CHAR(8),DATEADD(week, timeDateDiff,0),112)-完全備份日期+_0100-完全備份時間+差異備份+_+CONVERT(CHAR(8),GETDATE(),112)-差異備份日期+_030

10、0-差異備份時間SET strSqlCmd= strSql+.BAK-備份文件的擴展名BACKUP DATABASE webEIMS2021TO DISK = cSqlCmd WITH INIT,NOUNLOAD,DIFFERENTIAL,NAME = NMyDb差異備份,NOSKIP,STATS = 10,NOFORMAT我們可以看到,差異備份除了文件名命名格式不一樣外,就在備份執(zhí)行SQL語句時增加了了下DIFFERENTIA!#數(shù),然后再執(zhí)行。步驟二在命令框中執(zhí)行如下:DECLARE strSql VARCHAR(1000),strSqlCmd VARCHAR(1000),timeDate

11、Diff INT,strWeekDay VARCHAR(20)SET timeDateDiff= DATEDIFF(week,0,GETDATE()SET timeDateDiff= CASE DATEPART(WEEKDAY,GETDATE()WHEN 1 THEN timeDateDiff-1ELSE timeDateDiff ENDSET strSql=D:DataBaseBackDataMyDb_-備份目錄及備份的文件頭+CONVERT(CHAR(8),DATEADD(week,timeDateDiff,0),112)-完全備份日期+_0100-完全備份時間+差異備份+_+CONVER

12、T(CHAR(8),GETDATE(),112)-差異備份日期+_0300-差異備份時間SET strWeekDay= CASE DATEPART(WEEKDAY,GETDATE() WHEN 1星HEN WHEN 2 THEN星期一WHEN 3 THEN星期二WHEN 4 THEN星期三WHEN 5 THEN星期四WHEN 6 THEN星期五WHEN 7 THEN星期六ENDSET strSqlCmd= ECHO壓縮開始日期:+CONVERT(VARCHAR(20),GETDATE(),120)+ +strWeekDay+ D:DataBaseBackDataCompressDataBase

13、MyDb_+CONVERT(CHAR(6),DATEADD(week,timeDateDiff,0),112)+.txtEXEC master.dbo.XP_CMDSHELL strSqlCmd,NO_OUTPUTSET strSqlCmd= RAR.EXE A -R +strSql+.RAR +strSql+.BAK D:DataBaseBackDataCompressDataBaseMyDb_+CONVERT(CHAR(6),DATEADD(week,timeDateDiff,0),112)+.txtPRINT LEN(strSqlCmd)PRINT (strSqlCmd)EXEC mas

14、ter.dbo.XP_CMDSHELL strSqlCmd,NO_OUTPUTSET strSqlCmd= ECHO壓縮結(jié)束日期:+CONVERT(VARCHAR(20),GETDATE(),120)+ +strWeekDay+ D:DataBaseBackDataCompressDataBaseMyDb_+CONVERT(CHAR(6),DATEADD(week,timeDateDiff,0),112)+.txtEXEC master.dbo.XP_CMDSHELL strSqlCmd,NO_OUTPUT這時我們已經(jīng)建立好了步驟,只是現(xiàn)在建立作業(yè)調(diào)度的時候有些變化,我們 看圖五:圖五建立差異備份作業(yè)調(diào)度比照完全備份建立的作業(yè)調(diào)度,在這里我們可以看到,我們選擇的時間是除了周 日以外的每天夜里3點的時候,自動執(zhí)行此次調(diào)度。當然時間是自己靈活分配的,如數(shù)據(jù)發(fā)生的變化比擬大,我們可以選擇每天, 然后頻率選擇發(fā)生周期性短一點,這樣我們數(shù)據(jù)在遭到破壞的時候,我們就可以 及時的恢復(fù)了。如果在SQL Server2000中,我們可以建立如上的作業(yè)就可以對數(shù)據(jù)進行備 份了,而對丁SQL Server2005,還有一點細微的變化,因為它默認是不支持xp_cmdshell執(zhí)行命令的,S

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論