萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> 數據庫綜合 >> SqlServer備份數據庫的4種方式有哪些

SqlServer備份數據庫的4種方式有哪些

這篇文章主要介紹了SqlServer備份數據庫的4種方式,講解了用sqlserver的維護計劃、通過腳本+作業的方式備份數據庫(非xp_cmdshell和xp_cmdshell)、用powershell調用sqlcmd執行備份命令幾種方式,需要的朋友可以參考下。

1.用sqlserver的維護計劃

在這裡我就不給截圖演示了,這個比較簡單,無非就是通過sqlserver自己的維護計劃拖拽出2個一個‘備份數據庫'任務和一個‘清除維護'任務。

需要注意的點:

1)有備份任務裡邊選擇備份的庫盡量選‘所有用戶數據庫'這項,以免選擇了特定數據庫備份以後某天添加了新數據庫卻忘了勾選導致丟備份。

2)選項驗證備份集完整性和壓縮備份盡量都選上。

3)備份的路徑盡量別選磁盤根目錄。

2.通過腳本+作業的方式備份數據庫(非xp_cmdshell)。如果是多個庫的話自己寫個游標用動態sql的方式即可實現多庫備份,我這裡就提供個思路偷懶就不整理了。

復制代碼代碼如下:

DECLARE @filename VARCHAR(500)

DECLARE @date DATETIME

DECLARE @OLD_DATE DATETIME

SET @date=GETDATE()

SET @OLD_DATE=GETDATE()-5 --超過5天的備份即將被刪除

SET @FILENAME = 'E:\存放位置\數據庫名稱-'+CAST(DATEPART(YYYY,@DATE) AS VARCHAR(10))+'-'+CAST(DATEPART(MM,@DATE) AS VARCHAR(10))+'-'+CAST(DATEPART(DD,@DATE) AS VARCHAR(10))+'.BAK'

BACKUP DATABASE [數據庫名稱] TO DISK = @filename WITH COMPRESSION

EXECUTE master.dbo.xp_delete_file 0,N'E:\存放位置',N'bak',@OLD_DATE,1

GO

3.通過腳本+作業的方式備份數據庫(用xp_cmdshell),如果你覺得你們服務器的網絡、代碼、以及防火牆足夠安全可以開啟xp_cmdshell的方式來備份。

如果數據庫沒開啟xp_cmdshell的功能需要用以下腳本開通此功能,開通以後記得關閉sp_configure。

復制代碼代碼如下:

USE Master

GO

EXEC sp_configure 'show advanced options', 1;

GO

RECONFIGURE WITH OVERRIDE;

GO

EXEC sp_configure 'xp_cmdshell',1;

GO

RECONFIGURE WITH OVERRIDE;

GO

下邊是備份的腳本

復制代碼代碼如下:

DECLARE @DBNAME VARCHAR(128)

DECLARE @PATH VARCHAR(50)

DECLARE @SQL NVARCHAR(MAX)

DECLARE @DDATE VARCHAR(8)

SET @PATH = 'E:\BackUp'

SET @DDATE = convert(char(8),getdate(),112)

--刪除超過1天的備份

SET @SQL ='xp_cmdshell '' forfiles /p "'+@path+'" /d -0 /m *.bak /c "cmd /c echo deleting @file.... && del /f @file"'''

EXEC (@SQL)

SET @SQL = ''

SELECT @SQL = @SQL + '

BACKUP DATABASE ['+NAME+'] TO DISK = '''+@PATH+'\'+REPLACE(name,'.','')+@DDATE+'.bak '''

FROM master..sysdatabases

WHERE NAME NOT IN ('master','tempdb','model','msdb')

EXEC (@SQL)

4.用powershell調用sqlcmd來執行備份命令。

在master庫下邊寫好備份的存儲過程pr_1

然後創建powershell腳本,將下邊語句粘貼進去並保存成xx.ps1,在通過Windows的任務調度定時執行備份就可以了(我就是舉個例子過期刪除備份的語句也可以通過powershel實現,在家沒有環境就隨便寫個思路沒寫全各位見諒)。

復制代碼代碼如下:

$dbname = 'test'

write-host "------"$dbname

& cmd /c "sqlcmd -U sa -P 123456  -S 127.0.0.1 -Q `" pr_1 '$dbname'`

以上就是精品為大家提供的關於SqlServer備份數據庫的4種方式的相關內容,希望能夠幫助到大家。

copyright © 萬盛學電腦網 all rights reserved