科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道ADO.NET和LINQ中古怪的事务特性

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

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

LINQ中的事务依赖于TransactionScope,一个使用依赖全局变量的非OO设计模式的.NET 2.0类。不像在ADO.NET中的事务对象,TransactionScope不限于一个单独的数据库链接。

作者:Jonathan Allen/霍泰稳 编译 来源:天极软件 2007年9月10日

关键字: ADO LINQ 事务

  • 评论
  • 分享微博
  • 分享邮件

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

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章