这是我的备份,原文请看  http://www.dotblogs.com.tw/mis2000lab/archive/2014/11/12/transactionscope_promotable_transaction_net45.aspx

书本下集,有一章提及数据库交易与ADO.NET的用法

最简单的就是使用 System.Transaction命名空间里面的「TransactionScope来做

提醒您:

请先动手「加入参考」,才能呼叫 System.Transaction这个命名空间!

微软MSDN上面有篇文章,我看了还是不懂

套用我的方法,做中学

直接看程序代码

做了以后再来看文字讨论(抽象概念)

果然一次就搞懂了

................................................................................................................................................

数据源:与 SQL Server 进行
System.Transactions 整合

以下范例示范如何针对由两个不同的 SqlConnection对象(两个DB链接),

并包装于
TransactionScope区块中的两个不同 SQL Server实例,建立可提升(Promotable)交易。

using
(TransactionScope scope = new TransactionScope())

{

  // 第一个 DB连结

程序代码会使用 using…区块来建立
TransactionScope区块,并开启第一个连接,这样会自动在
TransactionScope中登记它。

  一开始交易登记为「轻量型(本机)交易」,而不是完全分布式交易。

using
(SqlConnection conn1 = new SqlConnection(connectString1))

{

try   {

conn1.Open();

SqlCommand com1 = new SqlCommand(SqlStr1, conn1);

com1.ExecuteNonQuery();

// 第二个 DB连结

只有当第一个连接中的Command”没有”掷回例外状况时,第二个连接才会登记于 TransactionScope中。

开启第二个连接时,交易会自动提升为「完全分布式交易」。

using
(SqlConnection conn2 = new SqlConnection(connectString2))

try   {

conn2.Open();

SqlCommand com2 = new SqlCommand(SqlStr2, conn2);

com2.ExecuteNonQuery();

}

catch (Exception ex2)  {

// 例外状况

}

}

catch (Exception ex1)   {

// 例外状况

}

}

scope.Complete();

//此时,系统会叫用 .Complete()方法,只有在”没有掷回”任何例外状况时才会认可交易。

}

................................................................................................................................................

从第一个连结 "成功"以后(登记为「轻量型(本机)交易」)

然后进入第二个连结(自动提升为「完全分布式交易」)

...... 这样的步骤就是「可提升(Promotable)交易」。

回头看看 MSDN上面讲过的这句话--

「除了增强程序设计之外,在处理交易时System.Transactions命名空间还会与 ADO.NET一起运作协调出最佳效能。

可提升的(Promotable)交易可以依照实际状况,自动提升为完全分布式交易的轻量型(本机)交易(lightweight
(local) transaction
)」

先做过一次,再来参阅理论(抽象观念),

是不是更清楚了呢?

相关文章,请参阅微软MSDN

SQL Server 进行 System.Transactions 整合

http://msdn.microsoft.com/zh-tw/library/ms172070(v=vs.110).aspx

System.Transaction (TransactionScope) 与 可提升 (Promotable) 交易的更多相关文章

  1. 事务使用中如何避免误用分布式事务(System.Transactions.TransactionScope)

    1:本地事务DbTransaction和分布式事务TransactionScope的区别: 1.1:System.Data.Common.DbTransaction: 本地事务:这个没什么好说了,就是 ...

  2. 如何避免误用分布式事务(System.Transactions.TransactionScope)

    以下内容来源与:http://www.cyqdata.com/cyq1162/article-detail-54453 1:本地事务DbTransaction和分布式事务TransactionScop ...

  3. 将不确定变为确定~transactionscope何时提升为分布式事务~SQL2005与SQL2008不同

    回到目录 Transactionscope何时被提升为分布式事务,即时要触发msdtc服务,这个问题与数据库版本有关,在前面的文章中,我的MSTDC系列出现了多个版本,有一点没有说清楚,测试的环境不同 ...

  4. EntityFramework与TransactionScope事务和并发控制

    最近在园子里看到一篇关于TransactionScope的文章,发现事务和并发控制是新接触Entity Framework和Transaction Scope的园友们不易理解的问题,遂组织此文跟大家共 ...

  5. 谈谈分布式事务之三: System.Transactions事务详解[上篇]

    在.NET 1.x中,我们基本是通过ADO.NET实现对不同数据库访问的事务..NET 2.0为了带来了全新的事务编程模式,由于所有事务组件或者类型均定义在System.Transactions程序集 ...

  6. TransactionScope的使用

    本文导读:在实际开发工作中,执行一个事件,然后调用另一接口插入数据,如果处理逻辑出现异常,那么之前插入的数据将成为垃圾数据,我们所希望的是能够在整个这个方法定义为一个事务,TransactionSco ...

  7. TransactionScope事务处理方法介绍及.NET Core中的注意事项 SQL Server数据库漏洞评估了解一下 预热ASP.NET MVC 的VIEW [AUTOMAPPER]反射自动注册AUTOMAPPER PROFILE

    TransactionScope事务处理方法介绍及.NET Core中的注意事项   作者:依乐祝 原文链接:https://www.cnblogs.com/yilezhu/p/10170712.ht ...

  8. WCF分布式开发步步为赢(12):WCF事务机制(Transaction)和分布式事务编程

    今天我们继续学习WCF分布式开发步步为赢系列的12节:WCF事务机制(Transaction)和分布式事务编程.众所周知,应用系统开发过程中,事务是一个重要的概念.它是保证数据与服务可靠性的重要机制. ...

  9. Spring.NET的中间数据层(Middle Tier Data Access)——事务管理(Transaction management)

    简介 Spring.NET为事务管理提供了一个持久化抽象(consistent abstraction ),其优点如下: 为不同事务API,例如ADO.NET,Enterprise Services, ...

随机推荐

  1. android 开发进阶 自定义控件-仿ios自动清除控件

    先上图: 开发中经常需要自定义view控件或者组合控件,某些控件可能需要一些额外的配置.比如自定义一个标题栏,你可能需要根据不同尺寸的手机定制不同长度的标题栏,或者更常见的你需要配置标题栏的背景,这时 ...

  2. python修改excel文件

    一.导入模块如图

  3. jmeter随笔(3)-从csv中获取带引号的数据详情

    最近在工作中,对jmeter实践的点滴的记录这里分享,不一定正确,仅供参考和讨论,有想法的欢迎留言.谈论. 1技巧1:从csv中获取带引号的数据详情 背景:我们从csv中获取数据,在jmeter中使用 ...

  4. Java垃圾收集器之--Garbage-First Collector

    简介       Garbage-First(G1)垃圾收集器全面支持JDK7 Upate 4及后续版本.G1收集器是一个服务器形式(server-style)的垃圾收集器,主要用于内存大.多处理器的 ...

  5. 洛谷P1268 树的重量

    P1268 树的重量 85通过 141提交 题目提供者该用户不存在 标签树形结构 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 有这种情况吗!!!! 题意似乎有问题 题目描述 树可以用来表 ...

  6. TCP/IP详解学习笔记(4)-- ARP 和 RARP

    1.ARP      地址解析协议(Address Resolution Protocol,ARP)是在仅知道主机的IP地址时确地址解析协议定其物理地址的一种协议.      在TCP/IP协议中,A ...

  7. C#中如何判断联系电话的合法性

    string tel = tb_tel.Text.Trim();//联系电话if (!string.IsNullOrEmpty(tb_tel.Text.Trim())){try{//num = Con ...

  8. .NET本质论(4)应用程序对象HttpApplication

    当HttpContext对象创建之后,HttpRuntime将随后创建一个用于处理请求的对象,这个对象的类型为HttpApplication.  在ASP.NET内部,HttpRuntime管理一个定 ...

  9. 二模08day2解题报告

    T1.引爆炸弹(bomb) N个炸弹构成一棵树,引爆一颗叶节点,会一直引爆到根节点.每颗炸弹有一个价值,求引爆k个炸弹的最大价值. 既然是一棵树,那么自然想到dp.所以先树形dp了一遍(由于可能出现多 ...

  10. Android添加权限大讲解

    对于新手来说,最烦恼的不是如何从网上下载到安卓项目,而是下载到的安卓项目不知道如何添加权限和要添加哪些权限. 现在就针对安卓的权限来讲解这些权限应该具体用在什么地方 首先在项目下找到 AndroidM ...