Get to know MDN better
Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit Juli 2015 browserübergreifend verfügbar.
* Einige Teile dieser Funktion werden möglicherweise unterschiedlich gut unterstützt.
Hinweis: Diese Funktion ist in Web Workers verfügbar.
Das IDBTransaction-Interface der IndexedDB API bietet eine statische, asynchrone Transaktion auf einer Datenbank mittels Ereignisbehandler-Attributen. Alle Lese- und Schreibvorgänge von Daten erfolgen innerhalb von Transaktionen. Sie verwenden IDBDatabase, um Transaktionen zu starten, IDBTransaction, um den Modus der Transaktion festzulegen (z. B. ob sie readonly oder readwrite ist), und greifen auf einen IDBObjectStore zu, um eine Anfrage zu stellen. Sie können auch ein IDBTransaction-Objekt verwenden, um Transaktionen abzubrechen.
EventTarget IDBTransactionTransaktionen werden gestartet, wenn die Transaktion erstellt wird, nicht wenn die erste Anfrage gestellt wird; ziehen Sie zum Beispiel folgendes in Betracht:
Nachdem der Code ausgeführt wurde, sollte der Objekt-Store den Wert "2" enthalten, da trans2 nach trans1 ausgeführt werden sollte.
Eine Transaktion wechselt zwischen aktiven und inaktiven Zuständen zwischen Aufgaben in der Ereignisschleife. Sie ist aktiv in der Aufgabe, in der sie erstellt wurde, und in jeder Aufgabe der success- oder error-Ereignisbehandler der Anfragen. In allen anderen Aufgaben ist sie inaktiv, in diesem Fall schlägt das Platzieren von Anfragen fehl. Wenn keine neuen Anfragen gestellt werden, wenn die Transaktion aktiv ist, und keine anderen ausstehenden Anfragen vorliegen, wird die Transaktion automatisch abgeschlossen.
Transaktionen können aus einer festen Anzahl von Gründen fehlschlagen, von denen alle (außer dem Absturz des Benutzer-Agents) einen Abbruch-Callback auslösen:
Beachten Sie, dass ab Firefox 40 IndexedDB-Transaktionen entspannte Haltbarkeitsgarantien haben, um die Leistung zu verbessern (siehe Firefox Bug 1112702). Früher wurde in einer readwrite-Transaktion ein complete-Ereignis nur ausgelöst, wenn alle Daten garantiert auf die Festplatte geschrieben worden waren. In Firefox 40+ wird das complete-Ereignis ausgelöst, nachdem dem Betriebssystem mitgeteilt wurde, die Daten zu schreiben, jedoch möglicherweise bevor diese Daten tatsächlich auf die Festplatte geschrieben wurden. Das complete-Ereignis kann also schneller als zuvor geliefert werden, jedoch besteht eine geringe Chance, dass die gesamte Transaktion verloren geht, wenn das Betriebssystem abstürzt oder es zu einem Stromausfall kommt, bevor die Daten auf die Festplatte geschrieben werden. Da solche katastrophalen Ereignisse selten sind, sollten sich die meisten Benutzer nicht weiter darum kümmern müssen.
Wenn Sie aus irgendeinem Grund Haltbarkeit sicherstellen müssen (z.B. wenn Sie kritische Daten speichern, die später nicht mehr berechnet werden können), können Sie eine Transaktion zwingen, vor der Lieferung des complete-Ereignisses auf die Festplatte zu schreiben, indem Sie eine Transaktion mit dem experimentellen (nicht standardisierten) readwriteflush-Modus erstellen (siehe IDBDatabase.transaction).
Die Datenbankverbindung, mit der diese Transaktion verknüpft ist.
IDBTransaction.durability SchreibgeschütztGibt den Haltbarkeitshinweis zurück, mit dem die Transaktion erstellt wurde.
IDBTransaction.error SchreibgeschütztGibt eine DOMException zurück, die den Fehlertyp angibt, der bei einer erfolglosen Transaktion aufgetreten ist. Diese Eigenschaft ist null, wenn die Transaktion nicht beendet ist, erfolgreich abgeschlossen wurde oder mit der IDBTransaction.abort()-Funktion abgebrochen wurde.
IDBTransaction.mode SchreibgeschütztDer Modus zur Isolierung des Zugriffs auf Daten in den Objekt-Stores, die im Geltungsbereich der Transaktion liegen. Der Standardwert ist readonly.
IDBTransaction.objectStoreNames SchreibgeschütztGibt eine DOMStringList der Namen von IDBObjectStore-Objekten zurück, die mit der Transaktion verknüpft sind.
Erbt von: EventTarget
IDBTransaction.abort()Macht alle Änderungen an Objekten in der mit dieser Transaktion verbundenen Datenbank rückgängig. Wenn diese Transaktion bereits abgebrochen oder abgeschlossen wurde, löst diese Methode ein Fehlerereignis aus.
IDBTransaction.objectStore()Gibt ein IDBObjectStore-Objekt zurück, das einen Objekt-Store repräsentiert, der Teil des Geltungsbereichs dieser Transaktion ist.
IDBTransaction.commit()Bei einer aktiven Transaktion die Transaktion abschließen. Beachten Sie, dass dies normalerweise nicht aufgerufen werden muss — eine Transaktion wird automatisch abgeschlossen, wenn alle ausstehenden Anfragen erfüllt wurden und keine neuen Anfragen gestellt wurden. commit() kann verwendet werden, um den Abschlussprozess zu starten, ohne auf Ereignisse von ausstehenden Anfragen warten zu müssen.
Hören Sie auf diese Ereignisse mit addEventListener() oder indem Sie einen Ereignisbehandler der oneventname-Eigenschaft dieses Interfaces zuweisen.
abortEin Ereignis, das ausgelöst wird, wenn die IndexedDB-Transaktion abgebrochen wird. Ebenfalls verfügbar über die onabort-Eigenschaft; dieses Ereignis wandert zu IDBDatabase.
completeEin Ereignis, das ausgelöst wird, wenn die Transaktion erfolgreich abgeschlossen wird. Ebenfalls verfügbar über die oncomplete-Eigenschaft.
errorEin Ereignis, das ausgelöst wird, wenn eine Anfrage einen Fehler zurückgibt und das Ereignis bis zum Verbindungsobjekt (IDBDatabase) hochwandert. Ebenfalls verfügbar über die onerror-Eigenschaft.
Veraltet: Diese Funktion wird nicht mehr empfohlen. Obwohl einige Browser sie möglicherweise noch unterstützen, könnte sie bereits aus den relevanten Webstandards entfernt worden sein, in Kürze entfernt werden oder nur noch aus Kompatibilitätsgründen bestehen. Vermeiden Sie die Verwendung und aktualisieren Sie vorhandenen Code, falls möglich; siehe die Kompatibilitätstabelle am Ende dieser Seite, um Ihre Entscheidung zu unterstützen. Beachten Sie, dass diese Funktion jederzeit aufhören könnte zu funktionieren.
Warnung: Diese Konstanten sind nicht mehr verfügbar — sie wurden in Gecko 25 entfernt. Sie sollten stattdessen die Zeichenfolgenkonstanten direkt verwenden. (Firefox-Bug 888598)
Transaktionen können einen von drei Modi haben:
| READ_ONLY | "readonly" (0 in Chrome) | Erlaubt das Lesen von Daten, aber nicht das Ändern. |
| READ_WRITE | "readwrite" (1 in Chrome) | Erlaubt das Lesen und Schreiben von Daten in vorhandenen Datenspeichern, um geändert zu werden. |
| VERSION_CHANGE | "versionchange" (2 in Chrome) | Erlaubt jede Operation, einschließlich solcher, die Objekt-Store und Indizes löschen und erstellen. Transaktionen in diesem Modus können nicht gleichzeitig mit anderen Transaktionen ausgeführt werden. Transaktionen in diesem Modus sind als "Upgrade-Transaktionen" bekannt. |
Auch wenn diese Konstanten jetzt veraltet sind, können Sie sie immer noch verwenden, um bei Bedarf Rückwärtskompatibilität bereitzustellen. Sie sollten defensiv programmieren für den Fall, dass das Objekt nicht mehr verfügbar ist:
Im folgenden Codebeispiel öffnen wir eine Lese-/Schreibtransaktion auf unserer Datenbank und fügen einem Objekt-Store Daten hinzu. Beachten Sie auch die Funktionen, die an Transaktionsereignisbehandler angehängt sind, um über das Ergebnis der Transaktionseröffnung im Falle von Erfolg oder Misserfolg zu berichten. Für ein vollständiges funktionierendes Beispiel siehe unsere To-do Notifications-App (Beispiel live ansehen).
| Indexed Database API 3.0 # transaction |
JavaScript aktivieren, um diese Browser-Kompatibilitätstabelle anzuzeigen.
Der Bauplan für ein besseres Internet.
Besuche die gemeinnützige Muttergesellschaft der Mozilla Corporation, die Mozilla Foundation.
Teile dieses Inhalts sind ©1998–2026 von einzelnen mozilla.org-Mitwirkenden. Inhalte sind verfügbar unter einer Creative-Commons-Lizenz.