Freigeben über


Wiederherstellen von Dateien und Dateigruppen über vorhandene Dateien (SQL Server)

Gilt für: SQL Server

In diesem Thema wird beschrieben, wie Sie Dateien und Dateigruppen über bestehende Dateien in SQL Server mithilfe von SQL Server Management Studio oder Transact-SQL wiederherstellen.

In diesem Thema

Vorbereitungen

Einschränkungen

  • Nur der Systemadministrator, der die Dateien und Dateigruppen wiederherstellt, darf zurzeit die wiederherzustellende Datenbank verwenden.

  • RESTORE ist nicht in einer expliziten oder implizierten Transaktion zulässig.

  • Bevor Sie mit dem vollständigen oder dem massenprotokollierten Wiederherstellungsmodell Dateien wiederherstellen können, müssen Sie das Protokoll der aktiven Transaktion (das sog. Protokollfragment) sichern. Weitere Informationen finden Sie unter Sichern eines Transaktionsprotokolls (SQL Server).

  • Um eine verschlüsselte Datenbank wiederherstellen zu können, muss das Zertifikat oder der asymmetrische Schlüssel verfügbar sein, das oder der zum Verschlüsseln der Datenbank verwendet wurde. Ohne das Zertifikat oder den asymmetrischen Schlüssel kann die Datenbank nicht wiederhergestellt werden. Darum muss das Zertifikat, das zur Verschlüsselung des Verschlüsselungsschlüssels für die Datenbank verwendet wurde, so lange beibehalten werden, wie die Sicherung benötigt wird. Weitere Informationen finden Sie unter SQL Server Certificates and Asymmetric Keys.

Sicherheit

Berechtigungen

Ist die wiederherzustellende Datenbank nicht vorhanden, muss der Benutzer über CREATE DATABASE-Berechtigungen verfügen, um RESTORE ausführen zu können. Ist die Datenbank vorhanden, werden RESTORE-Berechtigungen standardmäßig den Mitgliedern der festen Serverrollen sysadmin und dbcreator sowie dem Besitzer (dbo) der Datenbank erteilt (für die Option FROM DATABASE_SNAPSHOT ist die Datenbank immer vorhanden).

RESTORE-Berechtigungen werden Rollen erteilt, in denen Mitgliedsinformationen immer für den Server verfügbar sind. Da die Mitgliedschaft in einer festen Datenbankrolle nur bei unbeschädigten und zugänglichen Datenbanken geprüft werden kann (was beim Ausführen von RESTORE nicht immer der Fall ist), verfügen Mitglieder der festen Datenbankrolle db_owner nicht über RESTORE-Berechtigungen.

Verwendung von SQL Server Management Studio

So stellen Sie Dateien und Dateigruppen über vorhandene Dateien her

  1. Stellen Sie im Objekt-Explorer eine Verbindung mit einer Instance von SQL Server-Datenbank-Engine her, und erweitern Sie dann die Datenbanken.

  2. Klicken Sie mit der rechten Maustaste auf die gewünschte Datenbank, zeigen Sie auf Tasks, zeigen Sie auf Wiederherstellen, und klicken Sie anschließend auf Dateien und Dateigruppen.

  3. Geben Sie auf der Allgemein im Listenfeld In Datenbank die wiederherzustellenden Datenbank ein. Sie können eine neue Datenbank eingeben oder eine vorhandene Datenbank aus der Dropdownliste auswählen. Die Liste umfasst alle Datenbanken auf dem Server, mit Ausnahme der Datenbanken master und tempdb.

  4. Zum Festlegen von Quelle und Speicherort der wiederherzustellenden Sicherungssätze klicken Sie auf eine der folgenden Optionen:

    • Aus Datenbank

      Geben Sie im Listenfeld einen Datenbanknamen ein. Diese Liste enthält nur Datenbanken, die entsprechend dem Sicherungsverlauf von msdb gesichert wurden.

    • Von Gerät

      Klicken Sie auf die Schaltfläche zum Durchsuchen. Wählen Sie im Dialogfeld für das Angeben der Sicherungsgeräte einen der im Listenfeld Sicherungsmedientyp aufgeführten Medientypen aus. Klicken Sie zum Auswählen von einem oder mehreren Medien für das Listenfeld Sicherungsmedien auf Hinzufügen.

      Klicken Sie nach dem Hinzufügen der gewünschten Medien zum Listenfeld Sicherungsmedien auf OK , um zur Seite Allgemein zurückzukehren.

  5. Wählen Sie im Raster Wählen Sie die wiederherzustellenden Sicherungssätze aus die wiederherzustellenden Sicherungen aus. Mit diesem Raster werden die Sicherungen angezeigt, die für den angegebenen Speicherort verfügbar sind. Standardmäßig wird ein Wiederherstellungsplan vorgeschlagen. Sie können die Auswahl im Raster ändern, um den vorgeschlagenen Wiederherstellungsplan zu überschreiben. Für Sicherungen, die von einer Sicherung abhängig sind, für die die Auswahl aufgehoben wurde, wird die Auswahl automatisch aufgehoben.

    Spaltenkopf Werte
    Wiederherstellen Die aktivierten Kontrollkästchen zeigen die wiederherzustellenden Sicherungssätze an.
    Name Name des Sicherungssatzes.
    Dateityp Gibt den Typ der Daten in der Sicherung an: Daten, Protokolloder Filestream-Daten. Daten, die in Tabellen enthalten sind, befinden sich in Daten -Dateien. Transaktionsprotokolldaten befinden sich in Protokoll -Dateien. Blobdaten (Binary Large Object), die im Dateisystem gespeichert werden, befinden sich in Filestreamdaten -Dateien.
    Typ Der Typ der ausgeführten Sicherung: Vollständig, Differenzielloder Transaktionsprotokoll.
    Server Name der Instanz des Datenbankmoduls, durch die der Sicherungsvorgang ausgeführt wurde.
    Logischer Name der Datei Der logische Name der Datei.
    Datenbank Name der an der Sicherungsoperation beteiligten Datenbank.
    Startdatum Datum und Uhrzeit des Sicherungsbeginns, entsprechend den Ländereinstellungen des Clients.
    Beendigungsdatum Datum und Uhrzeit des Endes des Sicherungsvorgangs, entsprechend den Ländereinstellungen des Clients.
    Größe Größe des Sicherungssatzes in Byte.
    Benutzername Name des Benutzers, der den Sicherungsvorgang ausgeführt hat.
  6. Klicken Sie im Bereich Seite auswählen auf die Seite Optionen .

  7. Wählen Sie im Bereich Wiederherstellungsoptionen die Option Vorhandene Datenbank überschreiben (WITH REPLACE)aus. Der Wiederherstellungsvorgang überschreibt alle vorhandenen Datenbanken und die dazugehörigen Dateien, selbst wenn bereits eine Datenbank oder Datei mit demselben Namen vorhanden ist.

  8. Wählen Sie OK aus.

Verwenden von Transact-SQL

So stellen Sie Dateien und Dateigruppen über vorhandene Dateien her

  1. Führen Sie die RESTORE DATABASE-Anweisung aus, um die Datei- und Dateigruppensicherung wiederherzustellen, und geben Sie dabei Folgendes an:

    • Den Namen der wiederherzustellenden Datenbank.

    • Das Sicherungsmedium, von dem die vollständige Datenbanksicherung wiederhergestellt wird.

    • Die FILE-Klausel für jede wiederherzustellende Datei.

    • Die FILEGROUP-Klausel für jede wiederherzustellende Dateigruppe.

    • Die Option REPLACE, um anzugeben, dass jede Datei über vorhandene Dateien mit dem gleichen Namen und Speicherort wiederhergestellt werden kann.

      Achtung

      Verwenden Sie die Option REPLACE vorsichtig. Weitere Informationen finden Sie unter .

    • Die Option NRECOVERY. Wenn die Dateien nach dem Erstellen der Sicherung nicht geändert wurden, geben Sie die RECOVERY-Klausel an.

  2. Wenn die Dateien nach dem Erstellen der Sicherung geändert wurden, führen Sie die RESTORE LOG-Anweisung aus, um die Transaktionsprotokollsicherung anzuwenden, und geben Sie Folgendes an:

    • Den Namen der Datenbank, auf die das zu sichernde Transaktionsprotokoll angewendet wird.

    • Das Sicherungsmedium, von dem die Transaktionsprotokollsicherung wiederhergestellt wird.

    • Die NORECOVERY-Klausel, wenn nach der aktuellen Transaktionsprotokollsicherung eine weitere angewendet werden soll. Geben Sie andernfalls die RECOVERY-Klausel an.

      Die gegebenenfalls angewendeten Transaktionsprotokollsicherungen müssen den Zeitpunkt einschließen, zu dem die Dateien und Dateigruppen gesichert wurden.

Beispiel (Transact-SQL)

Im folgenden Beispiel werden die Dateien und Dateigruppen der MyNwind -Datenbank wiederhergestellt und alle vorhandenen Dateien mit demselben Namen ersetzt. Darüber hinaus werden zwei Transaktionsprotokolle angewendet, um die Datenbank zur aktuellen Zeit wiederherzustellen.

USE master;  
GO  
-- Restore the files and filesgroups for MyNwind.  
RESTORE DATABASE MyNwind  
   FILE = 'MyNwind_data_1',  
   FILEGROUP = 'new_customers',  
   FILE = 'MyNwind_data_2',  
   FILEGROUP = 'first_qtr_sales'  
   FROM MyNwind_1  
   WITH NORECOVERY,  
   REPLACE;  
GO  
-- Apply the first transaction log backup.  
RESTORE LOG MyNwind  
   FROM MyNwind_log1  
   WITH NORECOVERY;  
GO  
-- Apply the last transaction log backup.  
RESTORE LOG MyNwind  
   FROM MyNwind_log2  
   WITH RECOVERY;  
GO  

Weitere Informationen

Restore a Database Backup Using SSMS
RESTORE (Transact-SQL)
Wiederherstellen von Dateien und Dateigruppen (SQL Server)
Kopieren von Datenbanken durch Sichern und Wiederherstellen