1. 环境:
a)两台同样的Sql Server 2008 R2 服务器
b)操作系统都是windows 2008
c)需要将102.108.0.1数据库MSGC远程备份到112.118.0.2的服务器上, 库名保持不变
2. 打开102.108.0.1上Sql Server代理服务:
开始→控制面板→小图标→管理工具→服务→SQL Server 代理 (MSSQLSERVER)→启动
3. 在112.118.0.2上建立一个共享文件夹, 这里我将c:\data文件夹作为共享文件夹
4. 打开SQL Server Management Studio, 然后连接到102.108.0.1上
a)点开Sql Server代理, 右键作业→新建作业→名称备份MSGC→类别数据库维护→说明备份MSGC
b)接着上面的步骤, 不用点确定, 再点左侧的步骤→新建→新建作业→步骤名称: 备份MSGC→类型Transact-SQL脚本(T-SQL)→数据库MSGC, 在命令右侧的框中输入:
exec master..xp_cmdshell 'net use \\112.118.0.2\data woshiyigemima /user: 112.118.0.2\administrator' declare @ss varchar(50) set @ss = convert(varchar(100),GetDate(),112) set @ss ='\\112.118.0.2\\data\MSGC.bak' backup database MSGC to disk=@ss WITH FORMAT exec master..xp_cmdshell'net use \\112.118.0.2\data /delete'
解释: 利用xp_cmdshell创建一个网络映射, 把备份好的数据库, 远程存入到映射盘符中,data是112.118.0.2服务器的一个允许读写的共享文件夹,执行完成后,把映射删除掉,释放资源.
在使用cp_cmdshell创建网络映射时, 先要开启, 否则会有报错, 如下命令:
EXEC sp_configure 'show advanced options', 1;-- 允许配置高级选项--配置选项'show advanced options' 已从1 更改为1。请运行RECONFIGURE 语句进行安装。RECONFIGURE;-- 重新配置--命令已成功完成。EXEC sp_configure 'xp_cmdshell', 1;-- 开启xp_cmdshell--配置选项'xp_cmdshell' 已从1 更改为1。请运行RECONFIGURE 语句进行安装。RECONFIGURE;-- 重新配置--命令已成功完成。
exec master..xp_cmdshell 'net use \\112.118.0.2\data woshiyigemima /user: 112.118.0.2\administrator' -- net use \\112.118.0.2\data 允许网络读写的共享文件路径 -- woshiyigemima 112.118.0.2服务器的登录密码 --/user: 112.118.0.2\administrator 112.118.0.2的登录名declare @ss varchar(50) --声明变量set @ss = convert(varchar(100),GetDate(),112)-–赋值当前日期, 我这里没有使用set @ss ='\\112.118.0.2\\data\MSGC.bak' --最好是使用同名的备份, 否则还原的时候可能会有问题backup database MSGC to disk=@ss WITH FORMAT--WITH FORMAT可以做到覆盖任何现有备份和创建新媒体集exec master..xp_cmdshell'net use \\112.118.0.2\data /delete'--删除刚才创建的映射
5. 还是不要点确定, 接着点计划, 设置执行次数和执行时间
6. 如果想设置警报通知, 可以在警报→响应添加操作员; 然后在通知中选择一个电子邮件即可, 这里不再做详细的描述
7. 备份建立完成后, 整体如下图