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. 块语法Block在MVC思维的妙用之多重M层代理传值
  2. Desktop: ERROR: Cannot set priority of namenode process 35122
  3. SAP Analytics Path Framework的filter实现原理分析
  4. 18135usm_佳能PZ-E1+EF-S 18-135mm f/3.5-5.6 IS USM镜头 小型工作室的利器
  5. 待起飞的の集训8.5
  6. Navicat执行sql文件
  7. 怎么安装paraview_ParaViewWeb基于本地服务的环境部署
  8. 阻抗分析仪(LCR表)与矢量网络分析仪
  9. html 文字竖着排引号,文字竖排演示
  10. 汽车使用总结(七)--侧方停车
  11. 关于机器人方面的sci论文_科学网-2014年SCI收录机器人期刊22种目录-万跃华的博文...
  12. win10清理c盘_系统慢?给你的C盘减减肥!
  13. 热血格斗场(二分法+STL运用)
  14. 封装一个学生类Student(使用类与对象的方法)
  15. RFC2617- HTTP Authentication自译本-(3) (转)
  16. 如何读取STL文件?
  17. Word排版-页眉上的横线
  18. arcgis怎么关联excel表_arcgis中如何跟excel连接?
  19. Java踩坑记录-00001 BeanCreationException
  20. 华为S5700三层交换机不同VLAN互通

热门文章

  1. Memcached 未授权访问漏洞
  2. 极智AI | AIGC时代中AI巨头之间的博弈
  3. Hebbian principle
  4. CentOS7 yum源修改为阿里,配置阿里epel源
  5. Fascinating sort c语言 小悦是个聪明学生,给一个长度为N
  6. Oracle 11g 精简客户端
  7. 机器视觉 Histogram of oriented gradients
  8. Android mMediaRecorder.stop() 报错, 你蛋疼了吗?
  9. 一文快速回顾 Java 操作数据库的方式-JDBC
  10. 基于STM32F103C8T6的超声波与舵机综合应用的垃圾桶项目