• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SqlServer备份数据库的4种方式介绍
    POST TIME:2021-10-18 18:23

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

    以上就是常见的几种备份的方法,各位可以根据自己的业务场景来选择适合自己的备份方式。

    您可能感兴趣的文章:
    • sqlserver备份还原数据库功能封装分享
    • sqlserver2005 master与msdb数据库备份恢复过程
    • SQLServer 2005 自动备份数据库的方法分享(附图解教程)
    • Sqlserver2000 数据库备份实例代码
    • asp 在线备份与恢复sqlserver数据库的代码
    • sqlserver 自动备份所有数据库的SQL
    • sqlserver 数据库日志备份和恢复步骤
    • SqlServer批量备份多个数据库且删除3天前的备份
    上一篇:Windows下使用性能监视器监控SqlServer的常见指标
    下一篇:检测SqlServer数据库是否能连接的小技巧
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信