當前位置:首頁 » 編程軟體 » 編程數據恢復

編程數據恢復

發布時間: 2024-12-16 21:36:41

『壹』 如何使用腳本批量恢復資料庫備份

蛙蛙推薦:利用WMI腳本批量恢復sqlSERVER資料庫

問題提出

蛙蛙求助:以編程的方式還原sqlserver資料庫問題

我有一個目錄下面都是sqlserver的資料庫備份文件,比如a.bak,b.bak,c.bak等,有沒有辦法一下把他們都還原到本地SQLSERVER資料庫裡面呀,過程是自動建立a,b,c這樣的資料庫,然後把a.bak恢復到a,b.bak恢復到b,依次類推,因為備份文件的原路徑和新庫的路徑不一樣,所以要有一些額外處理,誰能解決一下,因為這個目錄下有幾十個庫的備份文件呢,現在我的機器新安裝了一個SQLSERVER,要把他們全部恢復,當時沒有分離庫,所以不能直接附加.

設計方案

可以利用WMI腳本掃描存放資料庫備份文件的目錄,然後按照一定的規則生成一個恢復資料庫的T-sql腳本文件,然後用腳本執行osql程序來執行這個腳本完成資料庫恢復,這里沒有使用過多的錯誤處理和事務的代碼,因此要人為的確定資料庫恢復的T-SQL語句盡量不要引發異常。

解決方案

一、我們先來看一下恢復資料庫的T-SQL命令,以便理解後面通過腳本來創建T-SQL的原理

USE master

GO

--如果要創建的資料庫已經存在,那麼刪除它

IF EXISTS (SELECT name FROM master.dbo.sysdatabases WHERE name = N'article')

DROP DATABASE [article]

GO

--創建一個新資料庫,要指定新建資料庫的數據文件和日誌文件的名稱和位置,初始化大小

--增長幅度,最大值等內容

CREATE DATABASE article

ON

( NAME = N'article_dat',

FILENAME = N'd:\sql2000\MSSQL\data\article_Data.MDF',

SIZE = 1,

MAXSIZE = 50,

FILEGROWTH = 5 )

LOG ON

( NAME = N'article_log',

FILENAME = N'd:\sql2000\MSSQL\data\article_Log.LDF',

SIZE = 1MB,

MAXSIZE = 25MB,

FILEGROWTH = 5MB )

GO

--把指定的資料庫備份文件恢復到剛剛建立的資料庫里,這里要指定資料庫備份文件的位置

--以及要恢復到的資料庫,因為備份文件來自未知的機器,備份的時候原資料庫和新資料庫

--的數據文件和日誌文件的位置不匹配,所以要用with move指令來完成強制文件移動,如果

--是通過管理器備份的資料庫文件,資料庫文件和日誌文件名分別是資料庫名跟上"_Data"或

--"_Log",這是一個假設哦,如果不是這樣,腳本有可能會出錯

RESTORE DATABASE [article]

FROM DISK = 'E:\windowdatabase\article.bak'

WITH

MOVE 'article_Data' TO 'd:\sql2000\MSSQL\data\article_Data.MDF',

MOVE 'article_Log' TO 'd:\sql2000\MSSQL\data\article_Log.LDF'

GO

從中可以看到T-SQL的強大。

『貳』 PLC可編程式控制制器 在斷電之後數據丟失,如何進行數據恢復

PLC可編程式控制制器 在斷電之後數據丟失,是無法進行數據恢復的!
還是重新編寫吧!祝你好運!

熱點內容
什麼是java框架 發布:2024-12-16 23:40:19 瀏覽:94
c語言合法浮點數 發布:2024-12-16 23:38:45 瀏覽:382
安卓包在哪裡刷 發布:2024-12-16 23:38:36 瀏覽:523
蘋果ipad清除緩存 發布:2024-12-16 23:24:51 瀏覽:606
系統崩潰linux 發布:2024-12-16 23:23:23 瀏覽:598
安卓手機上有什麼好的收音機 發布:2024-12-16 23:22:44 瀏覽:571
小8醬解壓碼 發布:2024-12-16 23:21:41 瀏覽:783
娃哈哈營銷腳本 發布:2024-12-16 23:21:06 瀏覽:711
怎麼才能找到自己的ID安卓 發布:2024-12-16 23:19:49 瀏覽:856
汽車銷售源碼 發布:2024-12-16 23:09:57 瀏覽:119