Abbildung 14.4 zeigt die beiden Transaktionstypen, die nach einem Fehler mit Verlust des Hauptspeicherinhalts zu behandeln sind:
Der Wiederanlauf geschieht in drei Phasen (Abbildung 14.5):
Spezielle Vorkehrungen müssen getroffen werden, um auch Fehler beim Wiederanlauf kompensieren zu können. Es wird nämlich verlangt, daß die Redo- und Undo-Phasen idempotent sind, d.h. sie müssen auch nach mehrmaliger Ausführung (hintereinander) immer wieder dasselbe Ergebnis liefern:
Für die Redo-Phase wird dies erreicht, indem jeweils die zum Log-Eintrag gehörende Log-Sequence-Number in den reservierten Bereich der Seite geschrieben und beim Zurückschreiben persistent wird. Hierdurch kann bei einem erneuten Redo überprüft werden, ob sich auf der Seite bereits das After Image befindet oder auf dem Before Image noch die Redo-Operation angewendet werden muss.
Während der Redo-Phase wird für jede durchgeführte Undo-Operation ein Compensation Log Record an die Log-Datei angehängt mit eigener LSN, so daßs bei einem erneuten Absturz in der nachfolgenden erneuten Redo-Phase diese Undo-Schritte unter Beachtung ihrer LSN-Einträge wiederholt werden können.