zoukankan      html  css  js  c++  java
  • 使用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

  • 相关阅读:
    Vue 计算属性(四)
    Vue 方法与事件(三)
    Vue 基本指令使用(二)
    Vue 项目开发环境搭建(一)
    SpringBoot 整合 Dubbo
    Nginx 中 include 指令使用
    Nginx 中 root 和 alias 的使用区别
    JS动态修改网站图标以及标题
    vue中使用轮播图插件carousel,克隆的图片点击事件无效的解决办法
    根据 url + fileName下载文件,并更改文件名
  • 原文地址:https://www.cnblogs.com/chenbg2001/p/1717932.html
Copyright © 2011-2022 走看看