SQL Server中通過擴充預存程序實現資料庫的遠程備份與恢複

來源:互聯網
上載者:User

本文通過執行個體解析了 SQL Server 資料庫擴充預存程序,實現遠程備份與恢複的方法和步驟
執行個體說明:

  環境:win2k+sqlserver 2K+查詢分析器
  SQL SERVER服務執行個體名稱:mainserver
  需要備份的資料庫名稱: msdb
  本地機器名稱(Client端):david
  本機使用者:zf 密碼:123
  本地區名:domain
  本地提供備份需求的檔案夾:e: est

  第一步: 建立共用資料夾

  在程式碼中調用(或者CMD視窗) net share test=e: est

  或者用NetShareAdd這個API

  簡要說明:

  net share: 是WINDOWS內部的網路命令。

  作用:建立本地的共用資源,顯示當前電腦的共用資源資訊。

  文法:參見 net share /?

  第二步: 建立共用信用關係

  master..xp_cmdshell 'net use \david est 123 /user:domainzf'

  簡要說明:

  1:xp_cmdshell :是SQLSERVER的擴充預存程序。

  作用,以作業系統命令列解譯器的方式執行給定的命令字串,

  並以文本行方式返回任何輸出。

  文法:參見SQLSERVER線上說明

  2:net use: 是WINDOWS內部的網路命令。

  作用,將電腦與共用資源串連或斷開,或者顯示關於電腦

  串連的資訊。該命令還控制持久網路連接。

  文法:參見 net use /?

  第三步:備份資料庫

  backup database msdb to disk='\david estmsdb.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: estmsdb.bak檔案了,使用起來很簡單吧?恢複資料庫操作也是一樣,只要將第三個步驟的語句改為'restore database msdb from disk='\david estmsdb.bak'就可以啦。。你看完了也可以試試呀?!(最簡單的測試載入器查詢分析器+CMD視窗)

  備忘:xp_cmdshell 這個擴充預存程序只能SA層級的使用者調用,而且是SQL Server的安全隱患之一,許多DBA都喜歡將其刪除或者禁用,所以開發人員使用時要倍加小心哦。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.