C# 的事务编程

1 Db事务

DbConnection 中创建基于当前连接的 DbTransaction

2  使用TransactionScope ,创建环境事务

一旦创建,在这个环境包含的DbConnection 实例 都会根据连接字符串中的

Sqlserver 连接字符串支持,是否自动附加当前环境事务.

连接字符串关键字(Enlist)

SqlConnection.ConnectionString 属性支持关键字 Enlist,该关键字指示 System.Data.SqlClient 是否将检测事务上下文并自动在分布式事务中登记连接。 如果 Enlist=true,连接将自动在打开的线程的当前事务上下文中登记。 如果 Enlist=false,SqlClient 连接不会与分布式事务进行交互。 Enlist 的默认值为 true。 如果连接字符串中未指定 Enlist,若在连接打开时检测到一个,连接将自动在分布式事务中登记。

Server=(local)SQL2005;Database=Northwind;Integrated Security=SSPI;auto-enlist=false

Mysql 等其他 OLDP数据库 需要驱动支持。

以下来自MSDN:

System.Transactions 基础结构提供了这两个的显式编程模型基于 Transaction 类,以及隐式编程模型使用 TransactionScope 类,在其中事务自动管理基础结构。

重要事项

建议您创建使用隐式事务 TransactionScope 类,以便为您自动管理环境事务上下文。您还应该使用 TransactionScope 和 DependentTransaction 跨多个函数调用或多个线程调用需要使用相同的事务的应用程序的类。此模型的详细信息,请参阅 Implementing An Implicit Transaction Using Transaction Scope 主题。编写事务应用程序的详细信息,请参阅 Writing A Transactional Application。

在实例化 TransactionScope 通过 new 语句中,事务管理器确定哪些事务参与进来。一旦确定,该范围将始终参与该事务。此决策基于两个因素:是否存在环境事务以及构造函数中 TransactionScopeOption 参数的值。环境事务是在代码中执行的事务。可通过调用 Current 类的静态 Transaction 属性,获取对环境事务的引用。有关如何使用此参数的详细信息,请参阅的"事务流的管理"部分 Implementing An Implicit Transaction Using Transaction Scope 主题。

如果在事务范围内未不发生任何异常 (即之间的初始化 TransactionScope 对象并调用其 Dispose 方法),则范围所参与的事务可以继续。如果在事务范围内发生异常,参与到其中的事务将回滚。

当您的应用程序完成所有工作时它想要在事务中执行,应调用 Complete 方法一次,以通知该事务管理器是可接受,即可提交事务。未能调用此方法中止事务。

调用 Dispose 方法将标记事务范围的末尾。在调用此方法之后所发生的异常不会影响事务。

如果您修改的值 Current 内某个范围内,将引发异常时 Dispose 调用。但是,在作用域结束时,以前的值被还原。此外,如果您调用 Dispose 上 Current 在事务范围创建事务,事务将中止范围的末尾。

//This function takes arguments for 2 connection strings and commands to create a transaction//involving two SQL Servers. It returns a value > 0 if the transaction is committed, 0 if the//transaction is rolled back. To test this code, you can connect to two different databases//on the same server by altering the connection string, or to another 3rd party RDBMS by//altering the code in the connection2 code block.

static public intCreateTransactionScope(string connectString1, stringconnectString2,string commandText1, stringcommandText2)

{//Initialize the return value to zero and create a StringWriter to display results.

int returnValue = 0;

System.IO.StringWriter writer= newSystem.IO.StringWriter();try{//Create the TransactionScope to execute the commands, guaranteeing//that both commands can commit or roll back as a single unit of work.

using (TransactionScope scope = newTransactionScope())

{using (SqlConnection connection1 = newSqlConnection(connectString1))

{//Opening the connection automatically enlists it in the//TransactionScope as a lightweight transaction.

connection1.Open();//Create the SqlCommand object and execute the first command.

SqlCommand command1 = newSqlCommand(commandText1, connection1);

returnValue=command1.ExecuteNonQuery();

writer.WriteLine("Rows to be affected by command1: {0}", returnValue);//If you get here, this means that command1 succeeded. By nesting//the using block for connection2 inside that of connection1, you//conserve server and network resources as connection2 is opened//only when there is a chance that the transaction can commit.

using (SqlConnection connection2 = newSqlConnection(connectString2))

{//The transaction is escalated to a full distributed//transaction when connection2 is opened.

connection2.Open();//Execute the second command in the second database.

returnValue = 0;

SqlCommand command2= newSqlCommand(commandText2, connection2);

returnValue=command2.ExecuteNonQuery();

writer.WriteLine("Rows to be affected by command2: {0}", returnValue);

}

}//The Complete method commits the transaction. If an exception has been thrown,//Complete is not called and the transaction is rolled back.

scope.Complete();

}

}catch(TransactionAbortedException ex)

{

writer.WriteLine("TransactionAbortedException Message: {0}", ex.Message);

}catch(ApplicationException ex)

{

writer.WriteLine("ApplicationException Message: {0}", ex.Message);

}//Display messages.

Console.WriteLine(writer.ToString());returnreturnValue;

}

transactionscope mysql_TransactionScope 的基本原理简介相关推荐

  1. TransactionScope 的基本原理简介

    C# 的事务编程 1 Db事务 DbConnection 中创建基于当前连接的 DbTransaction 2  使用TransactionScope ,创建环境事务 一旦创建,在这个环境包含的DbC ...

  2. 响应式编程 函数式编程_函数式编程的基本原理简介

    响应式编程 函数式编程 After a long time learning and working with object-oriented programming, I took a step b ...

  3. transactionscope mysql_TransactionScope事务操作

    using (TransactionScope trans = newTransactionScope()) {try{ InsertUserBase();//它插入不成功,自己回滚 UserInfo ...

  4. transactionscope mysql_TransactionScope事务对多个数据库的操作

    .Net 2.0引入了轻量级事务管理器(Lighweight Transaction Manager),即System.Transactions.TransactionManager. 轻量级事务管理 ...

  5. RabbitMQ的应用场景以及基本原理简介

    1.背景 RabbitMQ是一个由erlang开发的AMQP(Advanved Message Queue)的开源实现. 2.应用场景 2.1异步处理 场景说明:用户注册后,需要发注册邮件和注册短信, ...

  6. JS中函数式编程基本原理简介

    作者:TK  译者:前端小智  来源:medium 为了保证的可读性,本文采用意译而非直译. 在长时间学习和使用面向对象编程之后,咱们退一步来考虑系统复杂性. 在做了一些研究之后,我发现了函数式编程的 ...

  7. 音频编码 -(1)音频编码基本原理简介

    (1)  音频信号的冗余信息 数字音频信号如果不加压缩地直接进行传送,将会占用极大的带宽.例如,一套双声道数字音频若取样频率为44.1KHz,每样值按16bit量化,则其码率为: 2*44.1kHz* ...

  8. 存储程序通用计算机设计方案,第1章计算机设计方案基本原理.doc

    PAGE 58 PAGE 15 计算机设计基本原理 简介 半个多世纪以来,计算机技术取得了惊人的发展.1945年时还没有能存储程序的计算机.现在,花不到一千美元买到的个人计算机比1980年花一百万美元 ...

  9. 带你认识FusionInsight Flink:既能批处理,又能流处理

    摘要:本文主要介绍了FusionInsight Flink组件的基本原理.Flink任务提交的常见问题.以及最佳实践FAQ. 本文分享自华为云社区<FusionInsight HD Flink组 ...

最新文章

  1. 百度怎么不挣钱?一个吧居然有不下10种广告!
  2. WCF面向服务应用程序系列之一:Hello WCF
  3. php文件的作用,php入口文件的作用-PHP问题
  4. Saltstack 安装应用笔记一
  5. 阿里云云计算 8 ECS的实例规格
  6. redis 40道面试题
  7. Revit二次开发——标记/标注自动避让思路分享
  8. 模糊处理(下)--高斯模糊,双边模糊以及实现一个简单的磨皮美颜效果(opencv学习记录--4)
  9. 怎么在视频上叠加字幕和Logo--技术实现2
  10. Excel之VBA编程常用语句300句
  11. 【编程竞赛】【CSDN竞赛第37期】
  12. 独家 | 数据化思维、 数字化陷阱和 0.01 突破
  13. 看魔乐科技消息传送笔记
  14. 记住回家的路(周国平)
  15. 计算机网络中 中继器的作用是,请问在计算机网络中,中继器和放大器的区别是什么?...
  16. 如何实现,一人账号,全村人(宿舍)无限上网——校园网卡BUG篇-无锡科技职业学院
  17. 我的世界java要什么版本的电脑_《我的世界》配置要求 电脑版要什么样的配置...
  18. 45.qt quick-qml虚拟软键盘详解(一)
  19. ISO9001质量管理体系内容
  20. 微信跳一跳python全部代码_微信跳一跳辅助python代码实现

热门文章

  1. .Net5下Console.WriteLine()方法无输出
  2. 狂补计算机基础知识,让我上了瘾,想要尽快和同龄人拉开差距,必须这么干,才有戏!!!!
  3. 【五方面保养电脑延长寿命】
  4. 为什么计算机屏幕分辨率会,屏幕分辨率为什么调不了【解决方法】
  5. Word原来还能制作请柬,这些Word的骚操作你都知道多少呢?
  6. 全网最全的爆款抓包工具的综合对比
  7. iOS安全- 网络封包分析工具Charles
  8. Win server2019 搭建wds网络部署服务器
  9. errmsg:config:invalid signat
  10. php 唯一随机数,生成范围内的唯一随机数 - PHP