Sichern des Transaktionsprotokolls bei beschädigter Datenbank (SQL Server)
Gilt für: SQL Server
In diesem Thema wird beschrieben, wie ein Transaktionsprotokoll mithilfe von SQL Server Management Studio oder Transact-SQL gesichert wird, wenn die Datenbank in SQL Server beschädigt wird.
In diesem Thema
Vorbereitungen:
Sichern des Transaktionsprotokolls bei beschädigter Datenbank mit:
Vorbereitungen
Einschränkungen
- Die BACKUP-Anweisung ist nicht in einer expliziten oder implizierten Transaktion zulässig.
Empfehlungen
- Im Allgemeinen müssen Sie für eine Datenbank, die entweder das vollständige oder das massenprotokollierte Wiederherstellungsmodell verwendet, das Protokollfragment sichern, bevor Sie mit der Wiederherstellung der Datenbank beginnen. Vor dem Ausführen eines Failovers einer Protokollversandkonfiguration sollten Sie ebenfalls das Protokollfragment der primären Datenbank sichern. Das Sichern des Protokollfragments als abschließende Protokollsicherung vor dem Wiederherstellen der Datenbank vermeidet den Datenverlust nach einem Fehler. Weitere Informationen zu Sicherungen des Protokollfragments finden Sie unter Protokollfragmentsicherungen (SQL Server).
Sicherheit
Berechtigungen
Mitglieder der festen Serverrolle sysadmin und der festen Datenbankrollen db_owner und db_backupoperator verfügen standardmäßig über BACKUP DATABASE- und BACKUP LOG-Berechtigungen.
Besitz- und Berechtigungsprobleme im Zusammenhang mit der physischen Datei des Sicherungsmediums können den Sicherungsvorgang beeinträchtigen. SQL Server muss über Lese- und Schreibberechtigungen für das Medium verfügen. Das Konto, unter dem der SQL Server -Dienst ausgeführt wird, muss Schreibberechtigungen haben. Allerdings prüft die gespeicherte Prozedur sp_addumpdevice, die den Systemtabellen einen Eintrag für ein Sicherungsmedium hinzufügt, nicht die Dateizugriffsberechtigungen. Solche Probleme mit der physischen Datei des Sicherungsmediums treten möglicherweise erst auf, wenn auf die physische Ressource zugegriffen wird, um einen Sicherungs- oder Wiederherstellungsvorgang auszuführen.
Verwendung von SQL Server Management Studio
So sichern Sie das Transaktionsprotokollfragment
Klicken Sie nach dem Herstellen einer Verbindung mit der entsprechenden Instanz des Microsoft SQL Server-Datenbankmoduls im Objekt-Explorer auf den Servernamen, um die Serverstruktur zu erweitern.
Erweitern Sie Datenbanken, und wählen Sie je nach Datenbank eine Benutzerdatenbank aus, oder erweitern Sie Systemdatenbanken , und wählen Sie eine Systemdatenbank aus.
Klicken Sie mit der rechten Maustaste auf die Datenbank, zeigen Sie auf Tasks, und klicken Sie dann auf Sichern. Das Dialogfeld Datenbank sichern wird angezeigt.
Überprüfen Sie den Datenbanknamen im Listenfeld Datenbank . Sie können optional eine andere Datenbank aus der Liste auswählen.
Überprüfen Sie, ob als Wiederherstellungsmodell entweder FULL oder BULK_LOGGEDausgewählt wurde.
Wählen Sie im Listenfeld Sicherungstyp den Eintrag Transaktionsprotokollaus.
Lassen Sie Nur Sicherung kopieren deaktiviert.
Akzeptieren Sie im Bereich Sicherungssatz entweder den im Textfeld Name vorgeschlagenen Standardnamen für den Sicherungssatz, oder geben Sie einen anderen Namen für den Sicherungssatz ein.
Geben Sie im Textfeld Beschreibung eine Beschreibung für die Sicherung des Protokollfragments ein.
Geben Sie an, wann der Sicherungssatz ablaufen soll:
Wenn der Sicherungssatz nach einer bestimmten Anzahl von Tagen ablaufen soll, klicken Sie auf Nach (die Standardoption), und geben Sie an, nach wie vielen Tagen der Sicherungssatz abläuft. Dieser Wert kann zwischen 0 und 99999 Tagen liegen. Ein Wert von 0 Tagen bedeutet, dass der Sicherungssatz nicht abläuft.
Der Standardwert wird im Dialogfeld Servereigenschaften (Seite Datenbankeinstellungen ) über die OptionStandardbeibehaltung für Sicherungsmedien (in Tagen) festgelegt. Klicken Sie zum Zugreifen auf dieses Dialogfeld im Objekt-Explorer mit der rechten Maustaste auf den Servernamen, und wählen Sie „Eigenschaften“ aus. Wählen Sie anschließend die Seite Datenbankeinstellungen aus.
Zum Speichern des Sicherungssatzes an einem bestimmten Datum klicken Sie auf Am. Geben Sie das Datum ein, an dem der Sicherungssatz abläuft.
Wählen Sie den Sicherungszieltyp aus, indem Sie auf Datenträger oder Bandklicken. Klicken Sie auf Hinzufügen, um die Pfade von bis zu 64 Datenträgern oder Bandlaufwerken, die einen einzelnen Mediensatz enthalten, auszuwählen. Die ausgewählten Pfade werden im Listenfeld Sichern auf angezeigt.
Um einen Sicherungsziel zu entfernen, wählen Sie ihn aus, und klicken Sie auf Entfernen. Zum Anzeigen des Inhalts eines Sicherungsziels wählen Sie es aus, und klicken Sie auf Inhalt.
Wählen Sie auf der Seite Optionen eine Option von Medium überschreiben aus, indem Sie auf eine der folgenden Optionen klicken:
Auf vorhandenen Mediensatz sichern
Klicken Sie bei dieser Option entweder auf An vorhandenen Sicherungssatz anfügen oder auf Alle vorhandenen Sicherungssätze überschreiben.
Sie können bei Bedarf das Kontrollkästchen Mediensatznamen und Ablaufzeit des Sicherungssatzes überprüfen aktivieren, damit beim Sicherungsvorgang das Datum und die Uhrzeit überprüft werden, an dem bzw. zu der der Mediensatz und der Sicherungssatz ablaufen.
Geben Sie optional einen Namen im Textfeld Mediensatzname ein. Wenn kein Name angegeben wurde, wird ein Mediensatz mit leerem Namen erstellt. Wenn Sie einen Mediensatznamen angeben, wird überprüft, ob der tatsächliche Name des Mediums (Band oder Datenträger) mit dem eingegebenen Namen übereinstimmt.
Wenn Sie den Mediennamen leer lassen und das Kontrollkästchen aktivieren, um ihn anhand des Mediums zu überprüfen, ist die Prüfung erfolgreich, wenn der Medienname auf dem Medium ebenfalls leer ist.
Auf neuen Mediensatz sichern und alle vorhandenen Sicherungssätze löschen
Geben Sie bei dieser Option einen Namen in das Textfeld Name für neuen Mediensatz und optional eine Beschreibung des Mediensatzes in das Textfeld Beschreibung für neuen Mediensatz ein.
Weitere Informationen über Mediensätze finden Sie unter Mediensätze, Medienfamilien und Sicherungssätze (SQL Server).
Im Bereich Zuverlässigkeit können Sie folgende Optionen aktivieren:
Sicherung nach dem Abschluss überprüfen.
Vor dem Schreiben auf die Medien Prüfsumme bilden
Bei Prüfsummenfehler fortfahren
Weitere Informationen zu Prüfsummen finden Sie unter Mögliche Medienfehler während der Sicherung und Wiederherstellung (SQL Server).
Aktivieren Sie im Abschnitt Transaktionsprotokoll die Option Protokollfragment sichern und Datenbank im Wiederherstellungsstatus belassen.
Dies entspricht dem Angeben der folgenden BACKUP -Anweisung:
BACKUP LOG <database_name> TO <backup_device> WITH NORECOVERY
Wichtig
Zur Wiederherstellungszeit wird im Dialogfeld „Datenbank wiederherstellen“ der Typ einer Protokollfragmentsicherung als Transaktionsprotokoll (Nur Kopie)angezeigt.
Wenn Sie auf ein Bandlaufwerk sichern (gemäß der Konfiguration im Abschnitt Ziel der Seite Allgemein ), ist die Option Band nach dem Sichern entladen aktiviert. Wenn Sie auf diese Option klicken, wird die Option Band vor dem Entladen zurückspulen aktiviert.
SQL Server 2008 (10.0.x) Enterprise und höhere Versionen unterstützen die Sicherungskomprimierung. Ob eine Sicherung standardmäßig komprimiert wird, ist abhängig vom Wert der Serverkonfigurationsoption backup-compression default . Sie können jedoch unabhängig von der aktuellen Standardeinstellung auf Serverebene eine Sicherung komprimieren, indem Sie die Option Sicherung komprimierenaktivieren, oder die Komprimierung verhindern, indem Sie die Option Sicherung nicht komprimierenaktivieren.
So zeigen Sie die aktuelle Standardeinstellung für die Sicherungskomprimierung (Option "backup compression default") an
Verwenden von Transact-SQL
So erstellen Sie eine Sicherung des aktuell aktiven Transaktionsprotokolls
Führen Sie die BACKUP LOG-Anweisung aus, um das aktuell aktive Transaktionsprotokoll zu sichern, und geben Sie dabei Folgendes an:
Den Namen der Datenbank, zu der das zu sichernde Transaktionsprotokoll gehört.
Das Sicherungsmedium, auf das die Transaktionsprotokollsicherung geschrieben wird.
Die NO_TRUNCATE-Klausel.
Mit dieser Klausel ist ein Sichern des aktiven Teils des Transaktionsprotokolls auch dann möglich, wenn nicht auf die Datenbank zugegriffen werden kann. Voraussetzung hierfür ist allerdings, dass auf die Transaktionsprotokolldateien zugegriffen werden kann und diese unbeschädigt sind.
Beispiel (Transact-SQL)
Hinweis
In diesem Beispiel wird AdventureWorks2022
verwendet, das das einfache Wiederherstellungsmodell verwendet. Um Protokollsicherungen zu ermöglichen, wurde für die Datenbank vor dem Erstellen einer vollständigen Datenbanksicherung die Verwendung des vollständigen Wiederherstellungsmodells festgelegt. Weitere Informationen finden Sie unter Anzeigen oder Ändern des Wiederherstellungsmodells einer Datenbank (SQL Server).
In diesem Beispiel wird das derzeit aktive Transaktionsprotokoll bei einer beschädigten oder nicht erreichbaren Datenbank gesichert, sofern das Transaktionsprotokoll unbeschädigt und erreichbar ist.
BACKUP LOG AdventureWorks2022
TO MyAdvWorks_FullRM_log1
WITH NO_TRUNCATE;
GO
Weitere Informationen
Wiederherstellen einer Transaktionsprotokollsicherung (SQL Server)
Wiederherstellen einer SQL Server-Datenbank zu einem Zeitpunkt (vollständiges Wiederherstellungsmodell)
Datenbank sichern (Seite „Sicherungsoptionen“)
Datenbank sichern (Seite „Allgemein“)
Anwenden von Transaktionsprotokollsicherungen (SQL Server)
BACKUP (Transact-SQL)
Dateiwiederherstellungen (einfaches Wiederherstellungsmodell)
Dateiwiederherstellungen (vollständiges Wiederherstellungsmodell)