Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > TransactionScope的正确用法
【标  题】:TransactionScope的正确用法
【关键字】:TransactionScope
【来  源】:http://blog.csdn.net/greystar/archive/2006/11/01/1359960.aspx

TransactionScope的正确用法

Your Ad Here

前一阵贴了一个关于transactionscope的贴子,以为是MS的BUG。后来经过认真仔细的调试,才找到原因。

原来的代码本身是没有没问题的。只是关于事务资源的处理放错了地方。正确的写法应该如下

如果A类是使用数据库资源的。

class  A

{

SqlConnection cn=null;

public A()

{

.....

cn.open();

}

}

//开始事务

using(transactionscope scope=new transactionscope())

{

//要确保对支持事务的资源的登记放在此范围内,如数据库资源的打开

A a=new A();

a.method();

.....

scope.comlete()

我们只要确保数据库的打开操作是在事务范围内打开就行了。这样就可以做到事务的正确操作。

以前的代码是因为一个业务对象的初始化操作在外部进行了。尽管后来在事务范围内进行业务操作,也不行.

A a=new A();

using(transactionscope scope=new transactionscope())

{

//要确保对支持事务的资源的登记放在此范围内,如数据库资源的打开

 

a.method();

.....

scope.comlete()

上述代码,其实是没有参与任何事务的。对于子事务而已也是一样,只要保证事务登记在事务范围内才正确

我是查看了数据库中打开连接的情况才知道上面的原理。真是惭愧的很.

SQL Server 高频问题总结:【上一篇】
在ORACLE里用存储过程定期分割表〔转〕:【下一篇】
【相关文章】
没有相关文章
【随机文章】
  • 调试ASP,access时,like搜索出错的问题.
  • 520
  • 另类自启动病毒攻防战
  • 介绍宽带无源光纤接入网
  • Big Endian 和 Little Endian (1)
  • 存储参数(storage子句)含义及设置技巧
  • What Is Java
  • 某输入通1.34注册算法分析
  • 循环队列的程序
  • zero和null以及sparse
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 bbb软讯网络 All Rigths Reserved.