国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

SqlServer備份數據庫的4種方式介紹

2024-08-31 01:02:55
字體:
來源:轉載
供稿:網友

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

以上就是常見的幾種備份的方法,各位可以根據自己的業務場景來選擇適合自己的備份方式。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 白山市| 蓬莱市| 石渠县| 达日县| 隆德县| 平陆县| 婺源县| 嘉兴市| 土默特右旗| 恭城| 宜良县| 义马市| 开江县| 内江市| 阜宁县| 朝阳县| 镇宁| 凤阳县| 汤原县| 泰兴市| 中方县| 平山县| 怀化市| 东兰县| 荃湾区| 高密市| 赤壁市| 香河县| 阜宁县| 滦平县| 潞城市| 长汀县| 凤冈县| 西华县| 利辛县| 繁昌县| 农安县| 无为县| 泰和县| 策勒县| 台湾省|