Verteilte Transaktionen (ADO.NET)
Aktualisiert: November 2007
Bei einer Transaktion handelt es sich u. a. um mehrere zusammenhängende Aufgaben, die entweder in ihrer Gesamtheit erfolgreich abgeschlossen werden (Commit) oder nicht (Abort). Bei einer verteilten Transaktion handelt es sich um eine Transaktion, die sich auf verschiedene Ressourcen auswirkt. Damit ein Commit einer verteilten Transaktion erfolgreich ausgeführt werden kann, müssen alle Beteiligten gewährleisten, dass jede vorgenommene Datenänderung dauerhaft ist. Die Änderungen müssen auch bei Systemabstürzen oder anderen unvorhersehbaren Ereignissen erhalten bleiben. Sobald auch nur ein Beteiligter dies nicht gewährleisten kann, kann die gesamte Transaktion nicht ausgeführt werden, und sämtliche im Zuge der Transaktion durchgeführten Datenänderungen werden in einem Rollback zurückgenommen.
Hinweis: |
---|
Wenn Sie versuchen, einen Commit oder Rollback für eine Transaktion auszuführen, wenn ein DataReader gestartet wird und die Transaktion aktiv ist, wird eine Ausnahme ausgelöst. |
Arbeiten mit System.Transactions
In .NET Framework werden verteilte Transaktionen durch die API im System.Transactions-Namespace verwaltet. Die System.Transactions-API delegiert die Behandlung verteilter Transaktionen an einen Transaktionsmonitor wie den MS DTC (Microsoft Distributed Transaction Coordinator), wenn mehrere ständige Ressourcen-Manager beteiligt sind. Weitere Informationen finden Sie unter Transaktionsgrundlagen.
Ab ADO.NET 2.0 wird die Auflistung in einer verteilten Transaktion mithilfe der EnlistTransaction-Methode unterstützt, die eine Verbindung in einer Transaction-Instanz auflistet. In früheren Versionen von ADO.NET wurde die explizite Eintragung in verteilte Transaktionen mithilfe der EnlistDistributedTransaction-Methode einer Verbindung für das Eintragen einer Verbindung in eine ITransaction-Instanz durchgeführt, die aus Gründen der Abwärtskompatibilität unterstützt wird. Weitere Informationen zu Enterprise Services-Transaktionen finden Sie unter Interoperabilität mit Enterprise Services und COM+-Transaktionen.
Bei System.Transactions-Transaktionen mit dem .NET Framework-Anbieter für SQL Server anhand einer SQL Server 2005-Datenbank wird automatisch eine kompakte Transaction verwendet. Die Transaktion kann anschließend bei Bedarf zu einer vollständig verteilten Transaktion heraufgestuft werden. Weitere Informationen finden Sie unter Integration von 'System.Transactions' in SQL Server (ADO.NET).
Hinweis: |
---|
Die maximale Anzahl an verteilten Transaktionen, an denen eine Oracle-Datenbank gleichzeitig teilnehmen kann, liegt standardmäßig bei 10. Nach der zehnten Transaktion wird, bei Verbindung mit einer Oracle-Datenbank, eine Ausnahme ausgelöst. Oracle bietet keine Unterstützung für DDL innerhalb einer verteilten Transaktion. |
Automatisches Eintragen in eine verteilte Transaktion
Die automatische Eintragung ist die Standard- (und bevorzugte) Methode zum Integrieren von ADO.NET-Verbindungen in die System.Transactions. Ein Verbindungsobjekt trägt sich automatisch in eine vorhandene verteilte Transaktion ein, wenn es feststellt, dass eine Transaktion aktiv ist. Bei System.Transaction bedeutet dies, dass Transaction.Current nicht NULL ist. Die automatische Transaktionseintragung erfolgt beim Öffnen der Verbindung. Dies erfolgt nicht anschließend, auch wenn ein Befehl innerhalb des Gültigkeitsbereichs einer Transaktion ausgeführt wird. Die automatische Eintragung in vorhandene Transaktionen kann durch die Angabe von Enlist=false als Parameter der Verbindungszeichenfolge für eine ConnectionString oder von OLE DB Services=-7 als Parameter der Verbindungszeichenfolge für eine ConnectionString deaktiviert werden. Weitere Informationen zu Oracle- und ODBC-Parametern der Verbindungszeichenfolge finden Sie unter der ConnectionString oder der ConnectionString.
Manuelles Eintragen in eine verteilte Transaktion
Wenn die automatische Eintragung deaktiviert ist oder wenn Sie eine Transaktion eintragen müssen, die nach dem Herstellen der Verbindung begonnen wurde, können Sie eine vorhandene verteilte Transaktion mithilfe der EnlistTransaction-Methode des DbConnection-Objekts für den entsprechenden Anbieter eintragen. Durch das Eintragen in eine vorhandene verteilte Transaktion wird sichergestellt, dass bei einem Commit oder Rollback der Transaktion auch die Änderungen einbezogen werden, die vom Code an der Datenquelle vorgenommen wurden.
Das Eintragen in verteilte Transaktionen eignet sich besonders beim Pooling von Geschäftsobjekten. Wenn sich ein Geschäftsobjekt mit einer hergestellten Verbindung in einem Pool befindet, erfolgt die automatische Transaktionseintragung nur, wenn diese Verbindung hergestellt wird. Wenn mehrere Transaktionen unter Verwendung des Geschäftsobjekts im Pool ausgeführt werden, wird die für das Objekt hergestellte Verbindung nicht automatisch in neu initialisierte Transaktionen eingetragen. In diesem Fall können Sie die automatische Transaktionseintragung für die Verbindung deaktivieren und die Verbindung mithilfe der EnlistTransaction-Methode in Transaktionen eintragen.
Die EnlistTransaction -Methode erhält ein einzelnes Argument vom Typ Transaction, das einen Verweis auf die vorhandene Transaktion darstellt. Nach dem Aufrufen der EnlistTransaction-Methode der Verbindung werden alle Änderungen, die mit der Verbindung an der Datenquelle vorgenommen wurden, in die Transaktion eingetragen. Beim Übergeben eines NULL-Werts wird die Verbindung aus der aktuellen verteilten Transaktionseintragung ausgetragen. Beachten Sie, dass die Verbindung vor dem Aufrufen der EnlistTransaction-Methode hergestellt werden muss.
Hinweis: |
---|
Nachdem eine Verbindung ausdrücklich in eine Transaktion eingetragen wurde, kann sie solange nicht ausgetragen oder in eine andere Transaktion eingetragen werden, bis die erste Transaktion beendet wurde. |
Vorsicht: |
---|
Die EnlistTransaction-Methode löst eine Ausnahme aus, wenn die Verbindung bereits mithilfe ihrer BeginTransaction-Methode eine Transaktion begonnen hat. Wenn es sich bei der Transaktion jedoch um eine lokale Transaktion handelt, die an der Datenquelle begonnen wurde (z. B. die explizite Ausführung der BEGIN TRANSACTION-ANWEISUNG mithilfe eines SqlCommand), führt die EnlistTransaction-Methode einen Rollback der lokalen Transaktion durch und trägt sich selbst wie angefordert in die vorhandene verteilte Transaktion ein. Sie werden nicht über den Rollback der lokalen Transaktion benachrichtigt und müssen nicht begonnene lokale Transaktionen mithilfe der BeginTransaction-Methode verwalten. Wenn Sie den .NET Framework-Datenanbieter für SQL Server (SqlClient) zusammen mit SQL Server 2005 verwenden, wird beim Eintragen eine Ausnahme ausgelöst. Alle anderen Fälle bleiben unerkannt. |
Heraufstufbare Transaktionen in SQL Server 2005
SQL Server 2005 unterstützt heraufstufbare Transaktionen, bei denen eine lokale kompakte Transaktion nur bei Bedarf automatisch zu einer verteilten Transaktion heraufgestuft werden kann. Eine heraufstufbare Transaktion ruft den zusätzlichen Aufwand einer verteilten Transaktion nicht auf, wenn kein zusätzlicher Aufwand erforderlich ist. Weitere Informationen sowie ein Codebeispiel finden Sie unter Integration von 'System.Transactions' in SQL Server (ADO.NET).
Konfigurieren von verteilten Transaktionen
Wenn Sie ein neueres Betriebssystem mit den neuesten Service Packs, z. B. Windows XP oder Windows Server 2003, verwenden, müssen Sie den MS DTC u. U. über das Netzwerk aktivieren, um verteilte Transaktionen verwenden zu können. Wenn die Windows-Firewall aktiviert ist (in Windows XP Service Pack 2 die Standardeinstellung), müssen Sie dem MS DTC-Dienst erlauben, das Netzwerk zu verwenden oder den MS DTC-Port zu öffnen.
Siehe auch
Konzepte
Integration von 'System.Transactions' in SQL Server (ADO.NET)