Skip to content
Advertisement

How to force extenal library to use SQL transaction

I have an external library to which I pass an instance of System.Data.SqlClient.SqlConnection and I want to wrap everything that library does on that connection in a transaction. When I was working with php/doctrine I would simply do exactly that in such cases – start a transaction in my code, call stuff on the library which issues DB queries and then commit the transaction in my code. When I tried to use this approach in C#, I got the following exception:

ExecuteScalar requires the command to have a transaction when the connection assigned to the command is in a pending local transaction. The Transaction property of the command has not been initialized.

So I took a look at the library code and it always uses SqlCommand without setting the Transaction property. Is it possible to achieve my goal somehow? (changing the library code isn’t feasible)

Advertisement

Answer

You haven’t posted your code but I assume you tried to use an explicit transaction by calling SqlConnection.BeginTransaction().

You can use a TransactionScope to create an implicit transaction. Any connection, command created inside the TransactionScope’s lifetime will be enlisted in a transaction automatically.

Copying from Implementing an Implicit Transaction using Transaction Scope‘s example:

The connection and both commands in this example run under a single transaction. Should an exception occur, the transaction will be rolled back.

User contributions licensed under: CC BY-SA
1 People found this is helpful
Advertisement