主頁(yè) > 知識(shí)庫(kù) > SqlServer備份數(shù)據(jù)庫(kù)的4種方式介紹

SqlServer備份數(shù)據(jù)庫(kù)的4種方式介紹

熱門標(biāo)簽:洛陽(yáng)外呼系統(tǒng)平臺(tái) 真人語(yǔ)音電銷機(jī)器人 廣州人工電銷機(jī)器人費(fèi)用 如何在地圖標(biāo)注自己店鋪 怎樣把地圖標(biāo)注導(dǎo)入公司地址 電銷機(jī)器人被曝光 400外呼系統(tǒng)合法 地圖標(biāo)注一個(gè)圓圈怎么用 寧波人工外呼系統(tǒng)有效果嗎

1.用sqlserver的維護(hù)計(jì)劃

在這里我就不給截圖演示了,這個(gè)比較簡(jiǎn)單,無(wú)非就是通過(guò)sqlserver自己的維護(hù)計(jì)劃拖拽出2個(gè)一個(gè)‘備份數(shù)據(jù)庫(kù)'任務(wù)和一個(gè)‘清除維護(hù)'任務(wù)。

需要注意的點(diǎn):

  1)有備份任務(wù)里邊選擇備份的庫(kù)盡量選‘所有用戶數(shù)據(jù)庫(kù)'這項(xiàng),以免選擇了特定數(shù)據(jù)庫(kù)備份以后某天添加了新數(shù)據(jù)庫(kù)卻忘了勾選導(dǎo)致丟備份。

  2)選項(xiàng)驗(yàn)證備份集完整性和壓縮備份盡量都選上。

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

2.通過(guò)腳本+作業(yè)的方式備份數(shù)據(jù)庫(kù)(非xp_cmdshell)。如果是多個(gè)庫(kù)的話自己寫個(gè)游標(biāo)用動(dòng)態(tài)sql的方式即可實(shí)現(xiàn)多庫(kù)備份,我這里就提供個(gè)思路偷懶就不整理了。

復(fù)制代碼 代碼如下:

  DECLARE @filename VARCHAR(500)
  DECLARE @date DATETIME
  DECLARE @OLD_DATE DATETIME
  SET @date=GETDATE()
  SET @OLD_DATE=GETDATE()-5 --超過(guò)5天的備份即將被刪除
  SET @FILENAME = 'E:\存放位置\數(shù)據(jù)庫(kù)名稱-'+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ù)庫(kù)名稱] TO DISK = @filename WITH COMPRESSION
  EXECUTE master.dbo.xp_delete_file 0,N'E:\存放位置',N'bak',@OLD_DATE,1

  GO


3.通過(guò)腳本+作業(yè)的方式備份數(shù)據(jù)庫(kù)(用xp_cmdshell),如果你覺(jué)得你們服務(wù)器的網(wǎng)絡(luò)、代碼、以及防火墻足夠安全可以開(kāi)啟xp_cmdshell的方式來(lái)備份。

  如果數(shù)據(jù)庫(kù)沒(méi)開(kāi)啟xp_cmdshell的功能需要用以下腳本開(kāi)通此功能,開(kāi)通以后記得關(guān)閉sp_configure。

復(fù)制代碼 代碼如下:

  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

  下邊是備份的腳本
復(fù)制代碼 代碼如下:
  
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)

--刪除超過(guò)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來(lái)執(zhí)行備份命令。

 在master庫(kù)下邊寫好備份的存儲(chǔ)過(guò)程pr_1

  然后創(chuàng)建powershell腳本,將下邊語(yǔ)句粘貼進(jìn)去并保存成xx.ps1,在通過(guò)Windows的任務(wù)調(diào)度定時(shí)執(zhí)行備份就可以了(我就是舉個(gè)例子過(guò)期刪除備份的語(yǔ)句也可以通過(guò)powershel實(shí)現(xiàn),在家沒(méi)有環(huán)境就隨便寫個(gè)思路沒(méi)寫全各位見(jiàn)諒)。

復(fù)制代碼 代碼如下:

$dbname = 'test'
write-host "------"$dbname
cmd /c "sqlcmd -U sa -P 123456  -S 127.0.0.1 -Q `" pr_1 '$dbname'`" "

以上就是常見(jiàn)的幾種備份的方法,各位可以根據(jù)自己的業(yè)務(wù)場(chǎng)景來(lái)選擇適合自己的備份方式。

您可能感興趣的文章:
  • sqlserver備份還原數(shù)據(jù)庫(kù)功能封裝分享
  • sqlserver2005 master與msdb數(shù)據(jù)庫(kù)備份恢復(fù)過(guò)程
  • SQLServer 2005 自動(dòng)備份數(shù)據(jù)庫(kù)的方法分享(附圖解教程)
  • Sqlserver2000 數(shù)據(jù)庫(kù)備份實(shí)例代碼
  • asp 在線備份與恢復(fù)sqlserver數(shù)據(jù)庫(kù)的代碼
  • sqlserver 自動(dòng)備份所有數(shù)據(jù)庫(kù)的SQL
  • sqlserver 數(shù)據(jù)庫(kù)日志備份和恢復(fù)步驟
  • SqlServer批量備份多個(gè)數(shù)據(jù)庫(kù)且刪除3天前的備份

標(biāo)簽:石家莊 煙臺(tái) 南昌 晉中 珠海 東營(yíng) 北海 咸寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SqlServer備份數(shù)據(jù)庫(kù)的4種方式介紹》,本文關(guān)鍵詞  SqlServer,備份,數(shù)據(jù)庫(kù),的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SqlServer備份數(shù)據(jù)庫(kù)的4種方式介紹》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于SqlServer備份數(shù)據(jù)庫(kù)的4種方式介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章