-
Notifications
You must be signed in to change notification settings - Fork 11
Transaction attribute (supports nhibernate or system.transaction. works with asp.net, wcf, windows gui and windows service applications)
The Transaction attribute described here uses Castle Interceptors (and no longer requires PostSharp). You also need to configure your application to use Castle Windsor.
You will need to reference the following DLLs in any project that uses transactions:
SharpArchContrib.Core.dll
SharpArchContrib.Castle.dll
SharpArchContrib.Data.dll
Castle.Core
Castle.Windsor
Transactions are a key feature of almost any application that works with a database. Typically, you have to have put code like the following in any method that will work with transactions:
NHibernateSession.CurrentFor(factoryKey).Transaction.Begin();
try {
//application logic here
NHibernateSession.CurrentFor(factoryKey).Transaction.Commit();
} catch {
NHibernateSession.CurrentFor(factoryKey).Transaction.Rollback();
}
Unfortunately, this logic is repetitive and obscures the application logic. Of course, S#arp Architecture has its own Transaction attribute. As good as it is, it won't work in Windows applications. It also is not capable of working in concert with Microsoft's System.Transaction transactions (TransactionScopes). S#arp Architecture Contrib's Transaction attribute takes care of all of this.
Using transactions in any application is as simple as putting the SharpArchContrib.Castle.NHibernate.Transaction attribute on your method as shown in the following example:
[Transaction]
public void DoTransaction() {
//do some work here
}
Transactions can be nested and the work properly. For example:
[Transaction]
public void DoTransaction() {
//do some work here
DoInnerPortion();
}
[Transaction]
public void DoInnerPortion() {
//do some more work here
}
Nested transactions work as one unit. If rollback occurs at any point in the transaction (e.g. an unhandled exception occurs), the entire transaction gets rolled back. If no exception occurs, the transaction is committed when the outermost scope completes.
Generally, exceptions that cause a rollback bubble-up to the caller. The only exception is the SharpArchContrib.Data.NHibernate.AbortTransactionException. Throwing this in a method attributed with the Transaction attribute will force a rollback without passing the exception up to the caller. For example:
[Transaction]
public void DoTransaction() {
//do some work here
if (someCondition) {
//force rollback
throw new AbortTransactionException();
}
}
As described in configure your application to use Castle Windsor, you can configure the Transaction attribute to use either standard NHibernate transactions or Microsoft's System.Transaction.TransactionScope. When using TransactionScope, the transaction attribute disconnects the NHibernate session, enters a transaction scope and then reconnects the NHibernate session. This allows the underlying ADO.NET connection to enlist in the transaction. There is not a large cost to this since in most cases a new database connection is not actually required. Instead, an existing connection comes out of the connection pool.