如何创建一个与TransactionScope一起使用的类?
只是想知道,如果我想创建一个可以在TransactionScope中使用的类,我想要在TransactionScope中使用,我需要实现什么?
那就是:我的类需要知道它在一个Transaction中,但是如何在Commit或Rollback上得到通知? 在Rollback上,我将如何实际回滚?
我假设我的类将具有“添加”,“更新”和“删除”等方法,这些方法仅修改临时更改列表,以及方法“读取”,需要检测它是否在事务中并返回修改或未修改的数据相应地,但是我需要一个以某种方式调用的方法Commit / Rollback?
我会订阅Transaction.TransactionCompleted事件吗? 如果是,我如何避免对同一交易的多个订阅?
我注意到事务没有ID,有没有办法管理/兼顾多个并发事务或嵌套事务?
System.Transactions的MSDN文档有很多内容,但似乎是针对消费者而不是实现者,所以我想知道某人是否有一个良好的来源(无论是在网上还是在书中)关于服务如何提供支持交易?
让我们假设我的类没有已经支持事务的底层存储,并且能够“通过它”。 我们假设我的课看起来像这样:
public class MyClass { private List _businessData; public void Create(Myobject data) { ... } public MyObject Read(string query) { ... } public void Update(Myobject data) { ... } public void Delete(Myobject data) { ... } }
本文对所需内容有一个很好的概述。 它比较旧了,但我相信这一切仍然适用。
总结一下这篇文章,您需要在Transaction类上调用一个Enlist
方法,并传入IEnlistmentNotification
的实现。