Sie sind hier: Wissen

Was ist System.Transactions ?

System.Transactions (System.Transactions.dll) ist ein neuer Namensraum ab der .NET FCL 2.0. Zentrale Funktionen sind:

Wichtigste Klassen

TransactionManager
Transaction

Wichtigste Schnittstellen

ITransaction
ICommitableTransaction
ITransactionManager

Implizite Transaktionen mit TransactionScope

Implizite Transaktionen sind eine elegante Möglichkeit, eine Transaktion zu nutzen. Nach der Instanziierung der Klasse System.Transactions.TransactionScope werden alle folgenden ADO.NET-Befehle automatisch in den MSDTC integriert (automatisches Enlistment). Die Transaktion gilt so lange, bis die Complete()-Methode auf dem TransactionScope-Objekt aufgerufen wird. Die Transaktion wird automatisch zurückgesetzt, falls eine Ausnahme erzeugt wird.

public long Buchung(long PSID, long FLID)
{
// --- Beginn der Transaktion
System.Transactions.TransactionScope tx = new System.Transactions.TransactionScope();
// --- Verarbeitung kann jetzt beginnen...
long RestPlaetze = 0;
RestPlaetze = Buche(PSID, FLID);
// --- Transaktion abschließen
tx.Complete();
// --- Transaktionsobjekt verwerfen
tx.Dispose();
return RestPlaetze;
}

Durch den Einsatz des using-Befehls kann der vorherige Code noch eleganter formuliert werden.

public long Buchung2(long PSID, long FLID)
{
using (System.Transactions.TransactionScope tx = new System.Transactions.TransactionScope())
{
// -- Verarbeitung kann jetzt beginnen...
long RestPlaetze = 0;
RestPlaetze = Buche(PSID, FLID);
tx.Complete();
return RestPlaetze;
}
}

Der Einsatz der Klasse TransactionScope bietet eine deklarative Möglichkeit, bestimmte Codeblöcke in einer Transaktion auszuführen. Der Entwickler nutzt sie, indem er sie zum Beispiel in einem using-Block instantanziiert und innerhalb des Blockes die transaktionalen Aufgaben durchführt. Dabei werden alle in dem Codeblock über ADO.NET zu einer Datenbank gesendeten Befehle Teil der Transaktion, also auch Befehle, die über Entity Framework oder Entity Framework Core gesendet werden. Auch andere transaktionale Ressourcen wie die das Transactional File System (TxF) und die Transactional Registry (TxR), die es beide seit Windows Vista bzw. Windows Server 2008 gibt, können Teil der Transaktion sein (wobei für TxF und TxR spezielle Win32-API-Aufrufe notwendig sind, die die .NET-Standardklassen in den Namensräzmen System.IO bzw. Microsoft.Win32.Registry nicht realisieren).

Um in den Genuss der Klasse TransactionScope zu kommen, bindet der Entwickler die Assembly System.Transactions.dll ein. Idealerweise wird diese Klasse innerhalb einer using-Anweisung verwendet. Somit sind der Beginn und das Ende der dadurch repräsentierten Transaktion klar umrissen. Der Zugriff auf transaktionale Ressourcen innerhalb eines TransactionScope-Bereichs erfolgt im Rahmen einer Transaktion. Um die Transaktion zu bestätigen (engl. commit), ruft der Entwickler am Ende des Scopes die Methode Complete() auf. Um die Transaktion zurückzurollen, unterlässt er dies und verläßt den Block anders (z.B. durch return und einen Laufzeitfehler).

Greift der Entwickler innerhalb eines TransactionScope-Bereichs auf mehr als eine transaktionelle Ressource zu, zum Beispiel auf zwei verschiedene Datenbanken, versucht TransactionScope eine verteilte Transaktion zu starten. Neben der Tatsache, dass dies mit einem nicht zu unterschätzenden Overhead einhergeht, müssen alle beteiligten Ressourcen verteilte Transaktionen unterstützen. Zusätzlich muss bei den betroffenen Rechnern der Distributed Transaction Coordinator (DTC), der mit Windows in Form eines Systemdienstes ausgeliefert wird, gestartet sein.
Greift der Entwickler hingegen über zwei verschiedene Verbindungen auf ein und dieselbe transaktionale Ressource zu (z.B. über zwei Datenbankverbindungen auf dieselbe Datenbank), hängt das Transaktionsverhalten vom verwendeten Datenbanktreiber ab. Unterstützt der Datenbanktreiber für diesen Fall den sogenannten Lightweight Transaction Manager (wie zum Beispiel der Treiber für Microsoft SQL Server), wird eine lokale Transaktion verwendet und der DTC-Dienste wird dann nicht gebraucht. Dies ist der Fall im folgenden Listing.

Mit der Klasse TransactionScope können Transaktionen auch verschachtelt werden. Wenn innerhalb eines Blocks, der eine TransactionScope-Instanz besitzt, eine weitere Instanz von TransactionScope erzeugt wird, muss durch den Parameter TransactionScopeOption das Verhältnis der Transaktionen spezifiziert werden. Mögliche Werte sind Required, RequiresNew und Suppress.

.NET-Klassen als Teilnehmer von Transaktionen

System.Transactions ermöglicht es auch, eine .NET-Klasse in eine MSDTC-Transaktion einzubinden bzw. eine Transaktion in einer .NET-Klasse zu beginnen und erst später in den MSDTC aufzunehmen. .NET-Klassen bilden sogenannte volatile Ressourcen, die einen Neustart des Prozesses nicht überstehen. Datenbanktransaktionen sind im Gegensatz dazu dauerhafte Transaktionen (Durable Transactions).
Eine .NET-Klasse, die eine volatile Ressource im Rahmen einer Transaktion bilden möchte, muss die Schnitt-stelle IEnlistmentNotification mit den Methoden Prepare(), Commit(), Rollback() und InDoubt() unterstützen.

Beratung & Support

Schulungen zu diesem Thema

 Anfrage für eine individuelle Schulung zum Thema System.Transactions  Gesamter Schulungsthemenkatalog

Bücher zu diesem Thema

  Blazor 9.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 9.0, C# 13.0 und Visual Studio 2022
  C# 13.0 Crashkurs
  Cross-Plattform-Apps mit .NET MAUI entwickeln
  Moderne Datenzugriffslösungen mit Entity Framework Core 9.0
  .NET 9.0 Update: Die Neuerungen in .NET 9.0 gegenüber .NET 8.0
  PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
  .NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
  .NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
  Concurrency with Modern C++: What every professional C++ programmer should know about concurrency
  C++20: Get the Details
  Blazor 8.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 8.0, C# 12.0 und Visual Studio 2022
  Moderne Datenzugriffslösungen mit Entity Framework Core 8.0
  C# 12.0 Crashkurs
  App-Entwicklung für Mobile und Desktop: Software Engineering mit .NET MAUI und Comet für iOS, Android, Windows und macOS
  Cross-Plattform-Apps mit .NET MAUI entwickeln
  Blazor 7.0: Blazor WebAssembly, Blazor Server und Blazor Hybrid
  C# 11.0 Crashkurs
  Moderne Datenzugriffslösungen mit Entity Framework Core 7.0
  PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
  C++ Core Guidelines Explained: Best Practices for Modern C++
  App Engineering: SwiftUI, Jetpack Compose, .NET MAUI und Flutter
  Vue.js 3 Crashkurs
  Moderne Datenzugriffslösungen mit Entity Framework Core 6.0
  Blazor 6.0: Blazor WebAssembly, Blazor Server und Blazor Desktop
  C# 10.0 Crashkurs
  Cross-Plattform-Apps mit Xamarin.Forms entwickeln
  Developing Web Components with TypeScript: Native Web Development Using Thin Libraries
  PowerShell – kurz & gut
  C# 9.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET 5.0, .NET Core und Xamarin
  ASP.NET Core Blazor 5.0: Blazor WebAssembly und Blazor Server - Moderne Single-Page-Web-Applications
  Windows PowerShell 5 und PowerShell 7: Das Praxisbuch
  Moderne Datenzugriffslösungen mit Entity Framework Core 5.0
  ASP.NET Core Blazor 3.1/3.2: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
  ASP.NET Core Blazor 3.0/3.1: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
  Moderne Datenzugriffslösungen mit Entity Framework Core 3.1
  C# 8.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 3.0
  Windows PowerShell 5.1 und PowerShell Core 6.1 - Das Praxishandbuch
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.1/2.2
  Moderne Webanwendungen für .NET-Entwickler: Server-Anwendungen, Web APIs, SPAs & HTML-Cross-Platform-Anwendungen mit ASP.NET, ASP.NET Core, JavaScript
  C# 7.3 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Modern Data Access with Entity Framework Core: Database Programming Using .NET, .NET Core, UWP, and Xamarin with C#
  Modernes C++: Concurrency meistern
  Windows PowerShell und PowerShell Core - Der schnelle Einstieg: Skriptbasierte Systemadministration für Windows, Linux und macOS
  Programmierung in Python
  C# 7.2 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.0/2.1
  Effizienter Datenzugriff mit Entity Framework Core: Datenbankprogrammierung mit C# für .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.0
  Windows PowerShell 5 und PowerShell Core 6 - Das Praxishandbuch
  Angular - Das Praxisbuch zu Grundlagen und Best Practices
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1 und 2.0-Preview2
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1
  Introducing Regular Expressions: JavaScript and TypeScript
  Introducing Web Development
  Introducing Bootstrap 4
  Programming Web Applications with Node, Express and Pug
  Einführung in TypeScript: Grundlagen der Sprache TypeScript 2
  Pug – Die Template-Engine für node.js
  Web-Programmierung mit Node, Express und Pug
  Windows PowerShell 5 – kurz & gut
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1
  Windows PowerShell 5.0 - Das Praxishandbuch
  PHP 7 und MySQL: Von den Grundlagen bis zur professionellen Programmierung
  Windows Scripting Lernen
  .NET Praxis - Tipps und Tricks für .NET und Visual Studio
  Grundlagen für Web-Entwickler: Protokolle, HTML und CSS
  Bootstrap 3 - Stile und Komponenten
  Bootstrap 4 - Stile und Komponenten
  Einführung in JavaScript: ECMAScript 5
  Einführung in node.js
  express – Middleware für node.js
  JADE – Die Template Engine für node.js
  Reguläre Ausdrücke in JavaScript
  Moderne Datenzugriffslösungen mit Entity Framework 6
  C++ Standardbibliothek
  AngularJS: Moderne Webanwendungen und Single Page Applications mit JavaScript
  Microsoft SharePoint Server 2013 und SharePoint Foundation: Das umfassende Handbuch
  SQL Server 2014 für Professionals: Hochverfügbarkeit, Cloud-Szenarien, Backup/Restore, Monitoring & Performance
  Moderne Webanwendungen mit ASP.NET MVC und JavaScript
  Windows PowerShell 4.0 - Das Praxishandbuch
  JavaScript: Das umfassende Handbuch, inkl. HTML5, JavaScript-Frameworks, jQuery, OOP
  C++11 für Programmierer
  C++ kurz und gut
  Microsoft ASP.NET 4.5 - Entwicklerbuch
  Moderne Webanwendungen mit ASP.NET MVC
  Verteilte Systeme und Services mit .NET 4.5
  Scripting mit Windows PowerShell 3.0 - Der Workshop: Skript-Programmierung mit Windows PowerShell 3.0 vom Einsteiger bis zum Profi
  Windows 8 für Administratoren
  Windows 8.1 - Das Handbuch (27. November 2013)
  Windows Store Apps entwickeln mit C# und XAML - Crashkurs
  .NET 4.5 Update
  Windows Scripting Lernen
  WPF 4.5 und XAML
  Datenbankprogrammierung mit .NET 4.5
  C++11: Der Leitfaden für Programmierer zum neuen Standard
  Verteilte Systeme und Services mit .NET 4.0
  Microsoft ASP.NET 4.0 mit C# 2010 - Entwicklerbuch
  Agile Software Engineering with Visual Studio
  Datenbankprogrammierung mit .NET 4.0. Mit Visual Studio 2010 und SQL Server 2008 R2
  Microsoft SharePoint Server 2010 und SharePoint Foundation 2010
  Microsoft SQL Server 2008 R2 - Das Entwicklerbuch
  Microsoft Viusal C# 2010
  Office 2010 Programmierung mit VSTO und .NET 4.0: Word, Excel und Outlook erweitern und anpassen
  Programmieren mit dem ADO.NET Entity Framework
  .NET 4.0 Crashkurs
  Visual Basic 2010: Grundlagen, ADO.NET, Windows Presentation Foundation
  .NET 4.0 Update
  Windows PowerShell 2.0 - Das Praxishandbuch
  Windows 7 im Unternehmen
  Agile Muster und Methoden
  Ajax
  ASP.NET 4.0
  ASP.NET 4.0 mit Visual C# 2010
  JavaScript
  PHP 5-Migration
  Scripting mit Windows PowerShell 2.0 - Der Einsteiger-Workshop
  SQL Server 2008 R2: Das Programmierhandbuch. Inkl. ADO.NET 3.5, LINQ to Entities und LINQ to SQL
  Visual Basic 2010
  Windows PowerShell 2.0 - Crashkurs
  Windows Server 2008 R2
  Windows Scripting
  Windows Scripting Lernen
  Data Mining mit Microsoft SQL Server
  Windows 7 für Administratoren
  Microsoft ASP.NET 3.5 mit Visual Basic 2008 - Entwicklerbuch
  .NET 3.5
  Essential PowerShell
  .NET 3.5 Crashkurs
  Webanwendungen mit ASP.NET 3.5 und AJAX Crashkurs
 Alle unsere aktuellen Fachbücher  E-Book-Abo für ab 99 Euro im Jahr