SqlServer備份數(shù)據(jù)庫的4種方式介紹
1.用sqlserver的維護計劃
在這里我就不給截圖演示了,這個比較簡單,無非就是通過sqlserver自己的維護計劃拖拽出2個一個‘備份數(shù)據(jù)庫'任務和一個‘清除維護'任務。
需要注意的點:
1)有備份任務里邊選擇備份的庫盡量選‘所有用戶數(shù)據(jù)庫'這項,以免選擇了特定數(shù)據(jù)庫備份以后某天添加了新數(shù)據(jù)庫卻忘了勾選導致丟備份。
2)選項驗證備份集完整性和壓縮備份盡量都選上。
3)備份的路徑盡量別選磁盤根目錄。
2.通過腳本+作業(yè)的方式備份數(shù)據(jù)庫(非xp_cmdshell)。如果是多個庫的話自己寫個游標用動態(tài)sql的方式即可實現(xiàn)多庫備份,我這里就提供個思路偷懶就不整理了。
DECLARE @filename VARCHAR(500)
DECLARE @date DATETIME
DECLARE @OLD_DATE DATETIME
SET @date=GETDATE()
SET @OLD_DATE=GETDATE()-5 --超過5天的備份即將被刪除
SET @FILENAME = 'E:\存放位置\數(shù)據(jù)庫名稱-'+CAST(DATEPART(YYYY,@DATE) AS VARCHAR(10))+'-'+CAST(DATEPART(MM,@DATE) AS VARCHAR(10))+'-'+CAST(DATEPART(DD,@DATE) AS VARCHAR(10))+'.BAK'
BACKUP DATABASE [數(shù)據(jù)庫名稱] TO DISK = @filename WITH COMPRESSION
EXECUTE master.dbo.xp_delete_file 0,N'E:\存放位置',N'bak',@OLD_DATE,1
GO
3.通過腳本+作業(yè)的方式備份數(shù)據(jù)庫(用xp_cmdshell),如果你覺得你們服務器的網(wǎng)絡、代碼、以及防火墻足夠安全可以開啟xp_cmdshell的方式來備份。
如果數(shù)據(jù)庫沒開啟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調(diào)用sqlcmd來執(zhí)行備份命令。
在master庫下邊寫好備份的存儲過程pr_1
然后創(chuàng)建powershell腳本,將下邊語句粘貼進去并保存成xx.ps1,在通過Windows的任務調(diào)度定時執(zhí)行備份就可以了(我就是舉個例子過期刪除備份的語句也可以通過powershel實現(xiàn),在家沒有環(huán)境就隨便寫個思路沒寫全各位見諒)。
$dbname = 'test'
write-host "------"$dbname
& cmd /c "sqlcmd -U sa -P 123456 -S 127.0.0.1 -Q `" pr_1 '$dbname'`" "
以上就是常見的幾種備份的方法,各位可以根據(jù)自己的業(yè)務場景來選擇適合自己的備份方式。
相關文章
SQL Server數(shù)據(jù)庫按百分比查詢出表中的記錄數(shù)
這篇文章主要介紹了SQL Server數(shù)據(jù)庫在一個表中按百分比查詢出記錄條數(shù)的方法及代碼示例,需要的朋友可以參考下2015-08-08如何將sql執(zhí)行的錯誤消息記錄到本地文件中實現(xiàn)過程
sql語句的錯誤信息都可以在sys.messages表里面找到,下面與大家分享下將sql 執(zhí)行的錯誤消息記錄到本地文件中,不會的朋友可以參考下哈2013-05-05自動清理 MSSQL Server Table Collation問題的解決方法
Cannot resolve the collation conflict between "Latin1_General_CI_AS" and "SQL_Latin1_General_CP1_CI_AS" in the equal to operation2013-02-02