SQL Server 远程备份数据库

在一些涉及到数据库的项目中,经常会有定时备份数据库的需要。定时备份到本机的话,还是挺容易的,计划任务就可以完成,但如果是整机挂了,那备份到本机是没意义的,那么就需要来考虑备份到局域网中,其它电脑里。

一开始我想得挺简单的,把远程的一个共享文件夹,映射到本地作为一个磁盘,使用 SQL Server 自带的备份功能去备份就好了。但实际操作下来,会发现根本就没有这个磁盘可以给你选,使用 SQL 语句来备份的话,也会提示错误。咋办呢?

网上找了很多的远程备份的方法,许多都用不了,有的还用 FTP 去上传… 这个超出了我们的需求,没必要了。下面就分享一份在网上找了之后,自己再简单整理过的代码,配合 SQL Server 代理中的作业功能,已经稳定运行一个星期了,每小时就备份一次。

复制代码
-- 创建网络映射(Y是盘符;IP地址后面要带共享文件夹的名称;password是密码,双引号引起;account是远程电脑的登录名)
exec master..xp_cmdshell 'net use Y: \\192.168.0.69\sqlbackup "password" /user:192.168.0.69\account'

-- 按日期时间做文件名(注意路径中的文件夹,需要先建立好)
declare @filename varchar(200)
select @filename = 'Y:\DB\' + replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ','-'),':','') + '.bak'

-- 执行备份(DB是要备份的数据库名称)
backup database [DB] to disk = @filename 

-- 删除网络映射(Y是盘符,同上)
exec master..xp_cmdshell 'net use Y: /delete'

-- ABEL.CNBLOGS.COM
-- 2013-07-14
复制代码

需要注意的是,SQL Server 要开启允许执行 cmd 命令。

我试过把网络映射保留着,不要删除,可是到了 backup database 的时候还是失败了,只能每次要备份都创建,然后再删除。如果有朋友知道是为什么,欢迎交流~~

转自:SQL Server 远程备份数据库 - ABEL - 博客园
http://www.cnblogs.com/abel/archive/2013/07/14/3188997.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值