当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL Server扩展存储过程实现远程备份与恢复

MSSQL
巧用SQL链接服务器访问远程Access数据库
SQL Server如何删除群集实例
安装SQL 2005中的AdventureWorks数据库
SQL Server 2008中有关XML的新功能
SQL Server注入大全及防御
Sql Server 2000视图中小心使用*符号
Sql Server导出指定条件的数据
SQL Server 2008的在线事务处理
介绍SQL Server 2008的四项新特性
SQL Server 2008在数据仓库方面的一些优点
触发器对SQL Server数据库进行备份
设置在Access项目中检索的记录数
SQL Server关于SQL Agent使用技巧
把sql server所有表的所有者改为dbo
IIS、SQL Server和ASP.NET安全设置解决方案
SQL Server 2005日志文件损坏怎么办?
SQL Server数据库字典SQL语句
临时表在SQL Server和MySql中创建的方法
SQL Server数据库查询优化3种技巧
SQL Server数据库开发10个问题

MSSQL 中的 SQL Server扩展存储过程实现远程备份与恢复


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 76 ::
收藏到网摘: n/a

  【 服务器学院】实例说明:
  
  
环境:win2k+sqlserver 2K+查询分析器
  SQLSERVER服务实例名称:mainserver
  需要备份的数据库名称: msdb
  本地机器名称(Client端):david
  本地用户:zf 密码:123
  本地域名:domain
  本地提供备份需求的文件夹:e:\test
  
  第一步: 建立共享文件夹
  
  在程序代码中调用(或者CMD窗口) net share test=e:\test
  或者用NetShareAdd这个API
  简要说明:
  net share   : 是WINDOWS内部的网络命令。
  作用:建立本地的共享资源,显示当前计算机的共享资源信息。
  语法:参见 net share /?
  
  第二步: 建立共享信用关系
  
  master..xp_cmdshell 'net use \\david\test 123 /user:domain\zf'
  简要说明:
  1:xp_cmdshell :是SQLSERVER的扩展存储过程。
  作用,以操作系统命令行解释器的方式执行给定的命令字符串,
  并以文本行方式返回任何输出。
  语法:参见SQLSERVER联机帮助
  2:net use   : 是WINDOWS内部的网络命令。
  作用,将计算机与共享资源连接或断开,或者显示关于计算机
  连接的信息。该命令还控制持久网络连接。
  语法:参见 net use /?
  
  第三步:备份数据库
  
  backup database msdb to disk='\\david\test\msdb.bak'
  这个不需要说明吧,语法参见SQLSERVER联机帮助
  
  第四步: 删除共享文件夹
  
  在程序代码中调用(或者CMD窗口) net share test /delete
  或者用NetShareDel这个API
  结果:
  已处理 1376 页,这些页属于数据库 'msdb' 的文件 'MSDBData'(位于文件 1 上)。
  已处理 1 页,这些页属于数据库 'msdb' 的文件 'MSDBLog'(位于文件 1 上)。
  BACKUP DATABASE 操作成功地处理了 1377 页,花费了 3.653 秒(3.086 MB/秒)。
  
  这样mainserver服务器上的msdb就备份到了david机器的E:\test\msdb.bak文件了,使用起来很简单吧?恢复数据库操作也是一样,只要将第三个步骤的语句改为'restore database msdb from disk='\\david\test\msdb.bak'就可以啦。。你看完了也可以试试呀?!(最简单的测试工具查询分析器+CMD窗口)
  
  备注:xp_cmdshell 这个扩展存储过程只能SA级别的用户调用,而且是SQLSERVER的安全隐患之一,许多DBA都喜欢将其删除或者禁用,所以开发人员使用时要倍加小心哦。