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;
sqlserver备份表语句
  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 @ && 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'`" "
以上就是常见的⼏种备份的⽅法,各位可以根据⾃⼰的业务场景来选择适合⾃⼰的备份⽅式。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。