程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> SqlServer備份數據庫的4種方法引見

SqlServer備份數據庫的4種方法引見

編輯:MSSQL

SqlServer備份數據庫的4種方法引見。本站提示廣大學習愛好者:(SqlServer備份數據庫的4種方法引見)文章只能為提供參考,不一定能成為您想要的結果。以下是SqlServer備份數據庫的4種方法引見正文


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'`" "

以上就是罕見的幾種備份的辦法,列位可以依據本身的營業場景來選擇合適本身的備份方法。

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