ADO.NET和LINQ中古怪的事务特性
2012-05-22 15:42
316 查看
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只能应用在当前线程上。
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只能应用在当前线程上。
相关文章推荐
- ADO.NET和LINQ中古怪的事务特性
- Linq to Entities in Ado.net EF的事务
- T-SQL中的事务处理、ADO.NET中的事务处理、LINQ to SQL中的隐式事务处理、分布式事务处理
- Linq to Entities in Ado.net EF的事务
- Linq to Entities in Ado.net EF的事务
- Linq to Entities in Ado.net EF的事务
- ADO.NET中事务的理解与应用
- Linq To Sql 与ADO.NET
- ADO.Net Linq to SQL and Linq to Entities Note
- 分别使用ADO.Net Entity Data Model 和Linq to Sql 建立数据访问层
- 在ADO.NET编写事务
- ado.net事务点滴之一 概述
- [Linq] Linq Over DataSet[Ado.net]
- LINQ TO SQL 和 ADO.NET ENTITY
- 【转载】ADO.NET与ORM的比较(3):Linq to SQL实现CRUD
- C#事务处理(二)之ADO.NET事务
- asp.net3.0新特性研究一Linq To Sql集成数据库语言的优点和缺点 (1)
- ADO.net 事务
- ADO.NET事务处理-數據存取時忽發事件處理
- ASP.NET里的事务处理(ado.net 数据库应用)