Eu recomendo usar TransactionScope , porque você pode usá-lo independentemente do banco de dados que estiver usando. Você pode até fazer transações distribuídas (operações em vários bancos de dados dentro da mesma transação) com ele.
Você pode consultar um link para um exemplo de código, mas, em geral, você faz isso:
try
{
using (TransactionScope scope = new TransactionScope())
{
using (MySqlConnection connection1 = new MySqlConnection (connectionString))
{
// Opening the connection automatically enlists it in the
// TransactionScope as a lightweight transaction.
connection1.Open();
// create the DB commands and perform the DB operations
.
.
.
// The Complete method commits the transaction. If an exception has been thrown,
// Complete is not called and the transaction is rolled back.
scope.Complete();
}
}
}
catch (Exception e)
{
// something went wrong, handle the exception accordingly. Note
// that since we did not call TransactionScope.Complete, nothing
// gets committed to the DB.
}