LINQ 中的事务 依赖于 TransactionScope ,一个使用依赖全局变量的非 OO 设计模式的.NET 2.0 类。
TransactionScope 被用来为一组变化设置事务。不像在 ADO.NET 中的事务对象,TransactionScope 不限于一个单独的数据库链接。它最常用的一个案例是在多台服务器上运行一个事务。
当一个 TransactionScope 对象被创建时,它会自动将自己注册成线程的事务。所有的事务感知操作也将会自动地使用这个事务,而不需要将事务对象传递给对象。事务感知对象的例子包括 SQLCommand 类和 LINQ to SQL 对象。
这种设计的一个比较严重的副作用是事务和操作间的连接不是那么直接。
Public Sub OperationWithTransaction() <br></br> Using t As New Transactions.TransactionScope <br></br> Operation1() <br></br> t.Complete() <br></br> End Using <br></br>End Sub
就上面的这个例子,当 OperationWithTransaction 被调用时,Operation1 函数中的所有动作都和事务相关联。就是在事务并没 有明确传递给方法的时候,这种情况也会发生。这就使得对 Operation1 的调试变得有些复杂,尤其是在堆栈跟踪(Stack Trace)上事务范围(transaction scope)被创建了多个层时。
最后需要提醒的是,在使用多线程时,一个给定的 TransactionScope 只能应用在当前线程上。
查看英文原文: The Curious Nature of Transactions in ADO.NET and LINQ
评论