本文目錄一覽:
如何使用腳本批量恢複數據庫備份
蛙蛙推薦:利用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的強大。
sql數據庫誤改怎樣恢復
1, 如果你有比較新的備份文件,可以將備份恢復到另外一台機器上,然後將對應表導入到當前庫;
2,如果你的日誌文件還沒有被覆蓋,將日誌文件copy出去,先備份一下,找個讀取sqlserver日誌的工具,從日誌文件中逐條記錄恢復。
oracle數據庫怎麼進行備份恢復,以及自動批量備份
Oracle數據庫備份,大致分為如下兩種:
第一種:邏輯備份:
使用EXP進行邏輯備份,在sql plus 執行:exp system/你的密碼 後按照提示命令執行即可。
第二種:物理備份
冷,熱備份的備份方法: 冷熱備份都是將數據庫文件做相應的拷貝。
冷備份:是指脫機備份,即將服務器停止掉。
熱備份:是指連機備份
使用該命令shutdown immediate停止服務器
數據庫備份與恢復原理
一般的文件型數據庫,實際上對整個就是一個或者多個文件,所謂的備份就是把這些文件考慮到其它介質上,可能有一個打包的過程,或者刻錄到DVD的過程。這是對文件型數據庫備份和恢復的最好方法,效率最好,操作最簡單。
有的大型數據庫,它自己管理存儲空間,是分區或者磁盤,不被操作系統識別。這類數據庫一樣可以用GHOST等工具備份磁盤。
可能許多人講備份數據庫是把數據庫轉換為SQL或者文本文件。其實這是另外一個概念,叫做數據遷移,目的是把數據庫的數據移植到其它數據庫管理系統。數據遷移不適合用來做數據庫的日常備份,一般關鍵數據庫不會平凡的做數據遷移。一般數據庫系統會提供專門的數據遷移工具,當然這類工具也可能就是一系列的SQL語句,自己也能編寫。
原創文章,作者:NWZW,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/139706.html