架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 15881|回复: 2

[资料] c#中TransactionScope的使用

[复制链接]
发表于 2017-4-10 10:16:25 | 显示全部楼层 |阅读模式
TransactionScope

TransactionScope是System.Transactions中的类,是.NET框架中自带的类。如果TransactionScope如果没有调用Complete方法就被释放(TransactionScope实现了IDisposible接口,建议使用using块)了,那么它会认为操作执行失败并将执行回滚。
TransactionScope是一个有用的API,它可以管理周围事务(“周围”意味着支持TransactionScope的数据库可以自动管理事务),大多数主流数据库都支持这个API,当然包括微软自家的MSSQL。
如果你使用的数据库或某些事务相关的系统不支持TransactionScope,那么仍然可以使用拦截器,但是必须修改代码使用合适的支持事务的API(比如,使用BeginTransaction API可以获得数据库provider的IDbTransaction的实现)。

QQ截图20170410101007.jpg

上面是我故意抛出一个自定义的异常,看是否能否正常回滚,下图是正常执行,没有异常。

QQ截图20170410101502.jpg


调用TransactionScope的Complete方法,表示事务成功执行。当然,如果事务总是执行成功的话,那就不需要事务了。之所以会有事务的原因就是解决多个操作中有失败的问题的,如果有操作失败就回滚。
因为这里使用的.NET的TransactionScope,没有显式的回滚调用,最接近的等价方式是使用Dispose方法。如果TransactionScope在Complete方法调用之前释放,那么TransactionScope就会执行回滚。因此,需要在事务拦截器切面中添加一个Dispose调用执行回滚。


最后,附上代码吧!


附上源码:
游客,如果您要查看本帖隐藏内容请回复






上一篇:在多语句事务内不允许使用 CREATE DATABASE 语句
下一篇:让Linq的OrderBy支持动态字段
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
 楼主| 发表于 2017-4-10 10:20:30 | 显示全部楼层
TransactionScope类是可以嵌套使用,如果要嵌套使用,需要在嵌套事务块中指定TransactionScopeOption参数。默认的这个参数为Required。

当嵌套类的TransactionScope的TransactionScopeOption为Required的时候,则可以看到如下结果,他们的事务的ID都是同一个。并且,只有当2个TransactionScope都complete的时候才能算真正成功。

如果把TransactionScopeOption设为RequiresNew,则嵌套的事务块和外层的事务块各自独立,互不影响。

TransactionScopeOption设为Suppress则为取消当前区块的事务,一般很少使用。
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-27 06:33

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表