博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用TransactionScope做分布式事务协调
阅读量:4353 次
发布时间:2019-06-07

本文共 1118 字,大约阅读时间需要 3 分钟。

//场景是使用在多个数据库之间的协调,.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

转载于:https://www.cnblogs.com/zhangyingai/p/7096359.html

你可能感兴趣的文章
luogu P1494 [国家集训队]小Z的袜子 ( 普 通 )
查看>>
树的数据结构
查看>>
MyEclipse导入Color Theme
查看>>
Vue开发微信H5 微信分享签名失败问题解决方案
查看>>
Linux - 配置SSH免密通信 - “ssh-keygen”的基本用法
查看>>
Python(2.7.6) glob - 匹配指定模式的文件
查看>>
HTTP - 持久连接
查看>>
添加路由时啥时候是dev啥时候是gw
查看>>
redis 中文字符显示
查看>>
登录日志分析常用查询
查看>>
Codeforces Round #228 (Div. 1) 388B Fox and Minimal path
查看>>
【nosql实现企业网站系列之一】mongodb的安装
查看>>
短信服务供应商价格总览
查看>>
获取本机IP(考虑多块网卡、虚拟机等复杂情况)
查看>>
笔记之_java整理ORM框架
查看>>
CentOS下安装python3.x版本
查看>>
CAP定理(原则)以及BASE理论
查看>>
「玩转树莓派」搭建属于自己的云盘服务
查看>>
有道语料库爬虫
查看>>
VS2019 实用设置
查看>>