transactionscope mysql_TransactionScope 的基本原理简介

transactionscope mysql_TransactionScope 的基本原理简介C#的事务编程1Db事务DbConnection中创建基于当前连接的DbTransaction2使用TransactionScope,创建环境事务一旦创建,在这个环境包含的DbConnection实例都会根据连接字符串中的Sqlserver连接字符串支持,是否自动附加当前环境事务.连接字符串关键字(Enlist)SqlConnection.ConnectionString属性…

大家好,又见面了,我是你们的朋友全栈君。

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数据库 需要驱动支持。

f42d7d1e7fa0736e0b93329fb9b349be.png

32fa6895f5fdab123a3026663f5e20ab.png

974c79340fbeee35baee9a0d346073c4.png

d848b16cb52292b753476fd916636ac9.png

以下来自MSDN:

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

IC160177.jpeg重要事项

建议您创建使用隐式事务 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;

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161935.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 二叉树层序遍历实现

    二叉树层序遍历实现二叉树的层序遍历下图是一个简单的二叉树例图实现思路:1.创建一个队列用于二叉树的层序遍历。2.将二叉树根节点插入队列中。3.通过while循环遍历二叉树,直至遍历完整个二叉树后则结束循环。4.每次循环开始时先进行出队操作,若当前出队元素为null则证明已经完成层序遍历结束循环循环,若不为null则打印该节点的值,并判断该节点是否存在左右子树,若存在则依次插入队列中。图解上述二叉树的层序遍历过程依次进行图上操作直至最终队列为空时则层序遍历结束。实现代码如下:classTreeNod

    2022年5月11日
    41
  • NLTK使用汇总_bom用量计算公式

    NLTK使用汇总_bom用量计算公式0.如何离线安装NLTK1.LookupError:Resourcenotfound.2.分句、分词和停用词3.词性标注和词形还原4.分句5.N-gram

    2025年7月21日
    5
  • python核心编程

    python核心编程1:正则表达式:正则表达式是包含文本和特殊字符的字符串,该字符串描述一个可以识别各种字符串的模式[A-Za-z]\w+的含义是第一个字符是字母,也就是说要么A~Z,要么a~z,后面是至少一个(+)

    2022年7月3日
    23
  • Struts2拦截器的学习「建议收藏」

    Struts2拦截器的学习「建议收藏」一.首先我应该先要了解Struts2拦截器的执行原理Struts 2的拦截器实现相对简单。当请求到达Struts2的ServletDispatcher时,Struts 2会查找配置文件,并根据其配置实例化相对的拦截器对象,然后串成一个列表(list),最后一个一个地调用列表中的拦截器。事实上,我们之所以能够如此灵活地使用拦截器,完全归功于“动态代理”的使用。动态代理是代理对象根据客户的需求做出…

    2022年10月7日
    3
  • arm的一些概念(ARM9、Cortex的区别)

    arm的一些概念(ARM9、Cortex的区别)arm的一些概念(ARM7、Cortex-M的区别)ARM7:ARMv4架构,ARM9:ARMv5架构,ARM11:ARMv6架构,ARM-Cortex系列:ARMv7架构。  ARM7没有MMU(内存管理单元),只能叫做MCU(微控制器),不能运行诸如Linux、WinCE等这些现代的多用户多进程操作系统,因为运行这些系统需要MMU,才能给每个用户进程分配进程自己独立的地址空间。uc…

    2022年5月30日
    34
  • navicat15 for mysql激活码【2021免费激活】「建议收藏」

    (navicat15 for mysql激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~14…

    2022年3月30日
    1.8K

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号