SqlServer备份数据库的4种方式介绍

作者:junjie 时间:2024-01-17 09:58:15 

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,备份,数据库
0
投稿

猜你喜欢

  • Python实现模拟锟斤拷等各类乱码详解

    2022-08-23 04:31:22
  • MySQL百万级数据大分页查询优化的实现

    2024-01-13 18:22:44
  • Mysql数据库使用concat函数执行SQL注入查询

    2024-01-18 04:55:35
  • 利用python实现数据分析

    2023-01-05 22:07:27
  • mysql 5.7更改数据库的数据存储位置的解决方法

    2024-01-21 11:56:43
  • Python计算回文数的方法

    2022-04-02 05:08:07
  • python基础之定义类和对象详解

    2023-06-15 05:35:12
  • python开发之Docker入门安装部署教程

    2022-12-08 18:31:28
  • python带你探寻WSGI Application原理

    2022-03-25 19:35:55
  • Python进程间通信之共享内存详解

    2022-01-06 05:47:10
  • CentOS 5.5使用yum来安装LAMP(php运行环境)

    2023-11-14 12:15:52
  • ansible作为python模块库使用的方法实例

    2022-07-15 08:01:02
  • python调用fortran模块

    2023-12-22 23:36:40
  • 分享个asp文件缓存代码,使程序从缓存读数据

    2011-03-09 19:47:00
  • 利用python绘制中国地图(含省界、河流等)

    2021-12-19 03:19:59
  • 高级消息队列协议AMQP简介

    2022-11-01 09:39:07
  • ASP.NET将Session保存到数据库中的方法

    2024-01-19 16:31:46
  • 在ASP中使用Oracle数据库技巧

    2008-05-17 11:47:00
  • php中fgetcsv()函数用法实例

    2023-06-15 05:50:37
  • Web 标准设计实践:Google 的首页

    2008-10-12 12:14:00
  • asp之家 网络编程 m.aspxhome.com