Yesky首页| 产品报价| 行情| 手机 | 数码 | 笔记本 | 台式机 | DIY硬件 | 外设 | 网络 | 数字家庭 | 评测 | 软件 | e时代 | 游戏 | 图片 | 壁纸 | 群乐 | 社区 | 博客 | 下载
软件频道>开发者网络>微软开发专栏>ASP.NETC#VB.NETVC.NET技术专题XML|软件频道产品中心群乐下载群乐:大家耍QQ
您现在的位置: 天极网 > 开发频道 > 微软开发专栏 > ADO.NET和LINQ中古怪的事务特性
全文

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

2007-08-19 09:42 作者: 作者 Jonathan Allen译者 霍泰稳 出处: 天极Yesky软件频道 责任编辑:方舟

  本文转自InfoQ,文中内容不代表本站观点,仅提供参考。

  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只能应用在当前线程上。

  参看原文链接

  查阅关于 LINQ 的全部文档

网友关注
最新上市
编辑推荐
欢迎订阅天极网RSS聚合资讯:http://www.yesky.com/index.xml