還原檔案和檔案群組 (SQL Server)
此主題描述如何使用 SQL Server Management Studio 或 Transact-SQL,在 SQL Server 2012 中還原檔案與檔案群組。
本主題內容
開始之前:
限制事項
安全性
若要使用下列項目還原檔案和檔案群組:
SQL Server Management Studio
Transact-SQL
開始之前
限制事項
負責還原檔案與檔案群組備份的系統管理員,必須是目前唯一正在使用即將還原之資料庫的人。
在明確或隱含的交易中,不允許使用 RESTORE。
在簡單復原模式之下,檔案必須屬於唯讀檔案群組。
在完整或大量記錄復原模式下,您必須先備份使用中的交易記錄 (也稱為記錄的結尾),才能還原檔案。 如需詳細資訊,請參閱<備份交易記錄 (SQL Server)>。
若要還原加密的資料庫,您必須能夠存取之前用來加密資料庫的憑證或非對稱金鑰。 如果沒有該憑證或非對稱金鑰,就無法還原資料庫。 因此,只要需要備份,就必須保留用來加密資料庫加密金鑰的憑證。 如需詳細資訊,請參閱<SQL Server 憑證與非對稱金鑰>。
安全性
權限
如果還原的資料庫不存在,使用者必須有 CREATE DATABASE 權限,才能執行 RESTORE。 如果資料庫存在,RESTORE 權限預設為系統管理員 (sysadmin) 和資料庫建立者 (dbcreator) 固定伺服器角色的成員以及資料庫的擁有者 (dbo) (對 FROM DATABASE_SNAPSHOT 選項而言,資料庫一律存在)。
RESTORE 權限提供給伺服器隨時可以取得其成員資格資訊的角色。 由於資料庫必須是可存取且未損毀,才能夠檢查固定資料庫角色成員資格,但執行 RESTORE 時未必如此,因此,db_owner 固定資料庫角色的成員並沒有 RESTORE 權限。
[Top]
使用 SQL Server Management Studio
若要還原檔案和檔案群組
連接到適當的 SQL Server Database Engine 執行個體之後,請在 [物件總管] 中按一下伺服器名稱以展開伺服器樹狀目錄。
展開 [資料庫]。 視資料庫而定,選取使用者資料庫,或者展開 [系統資料庫],再選取系統資料庫。
以滑鼠右鍵按一下資料庫,指向 [工作],然後按一下 [還原]。
按一下 [檔案和檔案群組],開啟 [還原檔案和檔案群組] 對話方塊。
在 [一般] 頁面上的 [目的地資料庫] 清單方塊,輸入要還原的資料庫。 您可以輸入新的資料庫,或者從下拉式清單中選擇現有的資料庫。 清單包含伺服器上的所有資料庫,排除系統資料庫 master 和 tempdb。
若要指定要還原之備份組的來源與位置,請按一下下列任一個選項:
來源資料庫
在清單方塊中輸入資料庫名稱。 此清單僅包含已根據 msdb 備份記錄而備份的資料庫。
來源裝置
按一下 [瀏覽] 按鈕。 在 [指定備份裝置] 對話方塊中,選取 [備份媒體類型] 清單方塊上列出的其中一個裝置類型。 若要選取 [備份媒體] 清單方塊的一個或多個裝置,請按一下 [加入]。
將您要的裝置加入 [備份媒體] 清單方塊後,按一下 [確定] 即可回到 [一般] 頁面。
在 [選取要還原的備份組] 方格中,選取要還原的備份。 這個方格會顯示指定位置可用的備份。 依預設,會建議一個復原計畫。 若要覆寫建議的復原計畫,您可以變更方格中的選取項目。 任何相依於已取消選取備份的備份,會自動被取消選取。
資料行標頭
值
還原
選取的核取方塊會指出要還原的備份組。
名稱
備份組的名稱。
檔案類型
指定備份中的資料類型:[資料]、[記錄檔] 或 [檔案資料流資料]。 資料表中所包含的資料位於 [資料] 檔案中。 交易記錄資料位於 [記錄檔] 中。 儲存在檔案系統上的二進位大型物件 (BLOB) 資料位於 [Filestream 資料] 檔案內。
型別
執行的備份類型:[完整]、[差異] 或 [交易記錄]。
伺服器
執行備份作業的 Database Engine 執行個體名稱。
檔案邏輯名稱
檔案的邏輯名稱。
資料庫
備份作業中所含的資料庫名稱。
開始日期
備份作業開始時的日期和時間,會出現在用戶端的地區設定中。
完成日期
備份作業完成時的日期和時間,會出現在用戶端的地區設定中。
大小
備份組的大小 (以位元組為單位)。
使用者名稱
執行備份作業的使用者名稱。
若要檢視或選取進階選項,請按一下 [選取頁面] 窗格中的 [選項]。
在 [還原選項] 面板中,您可以選擇下列任何選項 (如果情況適用)。
還原成檔案群組
指出正在還原整個檔案群組。覆寫現有的資料庫
指定還原作業應該覆寫任何現有的資料庫及其相關檔案,即使已經有另一個資料庫或檔案具有相同名稱也一樣。選取此選項相當於使用 Transact-SQL RESTORE 陳述式的 REPLACE 選項。
還原每個備份之前先提示
在將每個備份組還原之前,會要求您確認。您必須為不同的媒體集交換磁帶時,這個選項特別有用,例如當伺服器只有一個磁帶機時。
限制對還原資料庫的存取
僅有資料庫擁有者 (db_owner)、資料庫建立者 (dbcreator) 或系統管理員 (sysadmin) 的成員可以使用還原資料庫。選取此選項相當於使用 Transact-SQL RESTORE 陳述式的 RESTRICTED_USER 選項。
另外,您也可以在 [將資料庫檔案還原為] 方格中為每個檔案指定新的還原目的地,以將資料庫還原到新的位置。
資料行標頭
值
原始檔案名稱
來源備份檔案的完整路徑。
檔案類型
指定備份中的資料類型:[資料]、[記錄檔] 或 [檔案資料流資料]。 資料表中所包含的資料位於 [資料] 檔案中。 交易記錄資料位於 [記錄檔] 中。 儲存在檔案系統上的二進位大型物件 (BLOB) 資料位於 [Filestream 資料] 檔案內。
還原成
還原資料庫檔案的完整路徑。 若要指定新的還原檔案,請按一下文字方塊並編輯建議的路徑與檔案名稱。 變更 [還原成] 資料行中的路徑或檔案名稱相當於使用 Transact-SQL RESTORE 陳述式中的 MOVE 選項。
[復原狀態] 面板可決定資料庫在還原作業之後的狀態。
回復未認可的交易,讓資料庫保持備妥可用。無法還原其他交易記錄。(RESTORE WITH RECOVERY)
復原資料庫。 這是預設行為。 只有在您要立即還原所有必要的備份時,才選擇這個選項。 此選項相當於在 Transact-SQL RESTORE 陳述式中指定 WITH RECOVERY。讓資料庫保持不運作,且不回復未認可的交易。可以還原其他交易記錄。(RESTORE WITH NORECOVERY)
讓資料庫保持在還原狀態。 若要復原資料庫,就必須使用先前的 RESTORE WITH RECOVERY 選項 (請參閱上面說明) 執行另一個還原。 此選項相當於在 Transact-SQL RESTORE 陳述式中指定 WITH NORECOVERY。如果選取此選項,將無法使用 [保留複寫設定] 選項。
讓資料庫保持唯讀模式。回復未認可的交易,但是將回復作業儲存在檔案中,以便能夠恢復復原結果。(RESTORE WITH STANDBY)
讓資料庫處於待命狀態。 此選項相當於在 Transact-SQL RESTORE 陳述式中指定 WITH STANDBY。您必須指定待命資料庫檔案,才能選擇此選項。
回復恢復檔案
在 [回復恢復檔案] 文字方塊中,指定待命資料庫檔案名稱。 如果您讓資料庫保持唯讀模式 (RESTORE WITH STANDBY),就需要指定此選項。
[Top]
使用 Transact-SQL
若要還原檔案和檔案群組
執行 RESTORE DATABASE 陳述式以還原檔案及檔案群組備份,並指定以下項目:
所要還原的資料庫名稱。
將要還原完整資料庫備份的來源備份裝置。
替要還原的每個檔案指定 FILE 子句。
替要還原的每個檔案群組指定 FILEGROUP 子句。
NORECOVERY 子句。 如果檔案在備份建立之後沒有做過任何修改,請指定 RECOVERY 子句。
如果檔案在備份建立之後做過修改,則請執行 RESTORE LOG 陳述式以套用交易記錄備份,並指定下列項目:
交易記錄檔要套用的資料庫名稱。
用於還原交易記錄備份的備份裝置。
倘若在目前的交易記錄備份之後還有另一個交易記錄備份要套用,請指定 NORECOVERY 子句,否則請指定 RECOVERY 子句。
如果套用交易記錄備份,則交易記錄備份必須涵蓋備份檔案與檔案群組直到記錄結束的時間 (除非還原「所有的」資料庫檔案)。
範例 (Transact-SQL)
這個範例會還原 MyDatabase 資料庫的檔案和檔案群組。 為了將資料庫還原到目前的時間,還套用了兩份交易記錄。
USE master;
GO
-- Restore the files and filesgroups for MyDatabase.
RESTORE DATABASE MyDatabase
FILE = 'MyDatabase_data_1',
FILEGROUP = 'new_customers',
FILE = 'MyDatabase_data_2',
FILEGROUP = 'first_qtr_sales'
FROM MyDatabase_1
WITH NORECOVERY;
GO
-- Apply the first transaction log backup.
RESTORE LOG MyDatabase
FROM MyDatabase_log1
WITH NORECOVERY;
GO
-- Apply the last transaction log backup.
RESTORE LOG MyDatabase
FROM MyDatabase_log2
WITH RECOVERY;
GO
[Top]
請參閱
工作
還原資料庫備份 (SQL Server Management Studio)