使用TransactionScope做分布式事务协调

Posted 张英爱

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用TransactionScope做分布式事务协调相关的知识,希望对你有一定的参考价值。

//场景是使用在多个数据库之间的协调,.NET 2.0使用一个新的类型 TransactionScope来进行协调,这与之前的COM+协调是相对来说更加方便的

//需要引用一个新的程序集:System.Transactions
//需要特别注意一个地方,TransactionScope默认使用的事务隔离级别为串行化,那可能会太过于严格。所以应该根据需要进行必要的调整

//注意:还是需要MSDTC服务支持的。请用net start msdtc启用它

TransactionOptions options = new TransactionOptions();
options.Timeout = new TimeSpan(0, 0, 60);
options.IsolationLevel = IsolationLevel.ReadCommitted;
using (TransactionScope scope = new TransactionScope(options)) {

    try
    {
        SqlConnection conn1 = new SqlConnection("server=(local);database=demo;integrated security=true");
        conn1.Open();
        SqlCommand cmd1 = conn1.CreateCommand();
        cmd1.CommandText = "INSERT INTO Table1 VALUES(3)";
        cmd1.ExecuteNonQuery();
        SqlConnection conn2 = new SqlConnection("server=(local);database=northwind;integrated security=true");
        conn2.Open();
        SqlCommand cmd2 = conn2.CreateCommand();
        cmd2.CommandText = "DROP TABLE Table1";

        cmd2.ExecuteNonQuery();

        scope.Complete();//提交分布式事务

    }
    catch (SqlException ex)
    {

        MessageBox.Show(ex.Message);
    }

}

 

注意,TransactionScope不需要所谓的Rollback,只要没有Complete,那么在using语句块跳出的时候,就自动地Rollback

以上是关于使用TransactionScope做分布式事务协调的主要内容,如果未能解决你的问题,请参考以下文章

ADO.NET中的TransactionScope何时需要启用MSTDC(分布式事务管理)

关于分布式事务的一个误解:使用了TransactionScope就一定会开启分布式事务吗?

C#分布式事务解决方案-TransactionScope

分布式事务TransactionScope所导致几个坑

.net 中dapper实现事务的三种方式总结

在 WCF 中使用 TransactionScope 回滚 SQL 事务