繁体中文
设为首页
加入收藏
当前位置:技术首页 >> 开发 >> .Net >> ADO.NET和LINQ中古怪的事务特性

ADO.NET和LINQ中古怪的事务特性

2008-04-01 22:30:39  作者:IT动力源  来源:IT动力源收集整理  浏览次数:0  文字大小:【】【】【
关键字:asp .net

  LINQ中的事务 依赖于TransactionScope ,一个使用依赖全局变量的非OO设计模式的.NET 2.0类。

  TransactionScope被用来为一组变化设置事务。不像在ADO.NET中的事务对象,TransactionScope不限于一个单独的数据库链接。它最常用的一个案例是在多台服务器上运行一个事务。

  当一个TransactionScope对象被创建时,它会自动将自己注册成线程的事务。所有的事务感知操作也将会自动地使用这个事务,而不需要将事务对象传递给对象。事务感知对象的例子包括SQLCommand类和LINQ to SQL对象。

  这种设计的一个比较严重的副作用是事务和操作间的连接不是那么直接。

  Public Sub OperationWithTransaction() Using t As New Transactions.TransactionScope Operation1() t.Complete() End Using End Sub

  就上面的这个例子,当OperationWithTransaction被调用时,Operation1函数中的所有动作都和事务相关联。就是在事务并没 有明确传递给方法的时候,这种情况也会发生。这就使得对Operation1的调试变得有些复杂,尤其是在堆栈跟踪(Stack Trace)上事务范围(transaction scope)被创建了多个层时。

  最后需要提醒的是,在使用多线程时,一个给定的TransactionScope只能应用在当前线程上。


点击收藏到

责任编辑:fwr

本文引用地址: http://tech.itzero.com/2008/0401/28871.html 请粘贴到你的QQ/MSN上推荐给你的好友

相关文章
 

最新文章

更多

· ADO.NET和LINQ中古怪的事...
· ADO.NET在开发中的部分使...
· ado.net执行oracle 存储过程
· ado.net 如何读取 excel
· Ado.net快马加鞭
· 数据库开发个人总结(ADO...
· ado.net数据库连接
· 使用ADO.NET2.0提升数据...
· 使用ADO.NET2.0提升数据...
· 使用ADO.NET2.0提升数据...

热点文章

更多

· ADO.NET性能改善方法集合
· 初谈ADO.NET中利用DataA...
· 通过ADO.NET实现事务处理
· 通过ADO.NET存取文件
· 下一代ADO.NET---ADO.NE...
· ADO.NET2.0跟ADO.NET3.0...
· ADO.NET 2.0:如何排除错...
· ADO.NET中的sql连接
· 使用ADO.NET2.0提升数据...
· 使用ADO.NET2.0提升数据...

其它推荐