在一些涉及到数据库的项目中,经常会有定时备份数据库的需要。定时备份到本机的话,还是挺容易的,计划任务就可以完成,但如果是整机挂了,那备份到本机是没意义的,那么就需要来考虑备份到局域网中,其它电脑里。
一开始我想得挺简单的,把远程的一个共享文件夹,映射到本地作为一个磁盘,使用 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' -- 按日期时间做文件名(注意路径中的文件夹,需要先建立好) ) ),'-',''),' ','-'),':','') + '.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 的时候还是失败了,只能每次要备份都创建,然后再删除。如果有朋友知道是为什么,欢迎交流~~