• 分布式事务TransactionScope


    分布式事务TransactionScope
    以下是分布式事务的所有情况的例子了,包含了事务套事务,事务套存储过程事务,经过测试,TransactionScope对于分布式事务的各种情况支持的很好。

    使用分布式事务注意如下几点:

    1:确保参与事务的machine开启了分布式事务支持;

    2:如果machine开启了防火墙,需要设置msdtc进程为例外;

    3:参与事务的machine不能跨域(如果跨域,目前微软还没有确切的解决方案);

    4:多数据库时才使用分布式事务,如果是同一个数据库,最好使用SqlTransaction.

    using System;
    
    using System.Collections.Generic;
    
    using System.Linq;
    
    using System.Text;
    
    using System.Data;
    
    using System.Data.SqlClient;
    
    using System.Transactions;
    
    namespace ConsoleApplication16
    
    {
    
        class Program
    
        {
    
            static void Main(string[] args)
    
            {
    
                TestTransaction test = new TestTransaction();
    
     
    
                test.Test1();
    
                test.Test2();
    
                test.Test3();
    
                Console.ReadLine();
    
            }
    
        }
    
     
    
        public class TestTransaction
    
        {       
    
            public void Test1()
    
            {
    
                using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
    
                {
    
                    ExecuteQuery1("insert into user1 (username) values ('user1')");
    
                    ExecuteQuery1("insert into user2 (username) values ('user2')");
    
                    ExecuteQuery2("insert into user1 (username) values ('user1')");
    
                    ExecuteQuery2("insert into user2 (username) values ('user2')");
    
                    scope.Complete();
    
                }
    
            }
    
     
    
            public void Test2()
    
            {
    
                using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
    
                {
    
                    ExecuteQuery1(@"begin tran insert into user2 (username) values ('tran1') insert into user2 (username) values ('tran2') commit tran");
    
                    ExecuteQuery2(@"begin tran insert into user2 (username) values ('tran1') insert into user2 (username) values ('tran2') commit tran");
    
                    scope.Complete();
    
                }
    
            }
    
     
    
            public void Test3()
    
            {
    
                using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
    
                {
    
                    Test1();
    
                    Test2();
    
                    scope.Complete();
    
                }
    
            }
    
     
    
            private void ExecuteQuery1(string query)
    
            {
    
                string connectionString = "Data Source=wrf;Initial Catalog=test1;Integrated Security=True;";
    
                using (SqlConnection con = new SqlConnection(connectionString))
    
                {
    
                    using (SqlCommand com = new SqlCommand(query, con))
    
                    {
    
                        con.Open();
    
                        com.ExecuteNonQuery();
    
                    }
    
                }
    
            }
    
    
            private void ExecuteQuery2(string query)
    
            {
    
                string connectionString = "Data Source=192.168.1.113;Initial Catalog=test1;Persist Security Info=True;User ID=sa;Password=123;";
    
                using (SqlConnection con = new SqlConnection(connectionString))
    
                {
    
                    using (SqlCommand com = new SqlCommand(query, con))
    
                    {
    
                        con.Open();
    
                        com.ExecuteNonQuery();
    
                    }
    
                }
    
            }
    
        }
    
    }


  • 相关阅读:
    mybatis 源码分析(四)一二级缓存分析
    mybatis 源码分析(三)Executor 详解
    mybatis 源码分析(二)mapper 初始化
    mybatis 源码分析(一)框架结构概览
    Disruptor 详解 二
    Disruptor 详解 一
    JDK源码分析(12)之 ConcurrentHashMap 详解
    并发系列(7)之 ScheduledThreadPoolExecutor 详解
    数据结构系列(6)之 完全二叉堆
    并发系列(6)之 ThreadPoolExecutor 详解
  • 原文地址:https://www.cnblogs.com/apollokk/p/6713880.html
Copyright © 2020-2023  润新知