在前面一篇给出的Transaction的定义中,信息的读者应该看到了一个叫做DepedentClone的方法。该 方法对用于创建基于现有Transaction对象的“依赖事务(DependentTransaction)”。不像可提交事务 是一个独立的事务对象,依赖事务依附于现有的某个事务(可能是可提交事务,也可能是依赖事务)。 依赖事务可以帮助我们很容易地编写一些事务型操作,当环境事务不存的时候,可以确保操作在一个独 立的事务中执行;当环境事务存在的时候,则自动加入其中。
一、依赖事务(Dependent Transaction)
依赖事务通过DependentTransaction类型表示,DependentTransaction定义如下。和 CommittableTransaction一样,DependentTransaction也是Transaction的子类。既然 DependentTransaction依赖于现有的Transaction对象而存在,相当于被依赖事务的子事务,所以无法执 行对事务的提交,也自然不会定义Commit方法。但是,DependentTransaction具有一个唯一的方法成员 :Complete。调用这个方法意味着向被依赖事务发送通知,表明所有与依赖事务相关的操作已经完成。
1: [Serializable]
2: public sealed class DependentTransaction : Transaction
3: {
4: public void Complete();
5: }
1、通过DependentTransaction将异步操所纳入现有事务
通过Transaction的静态属性Current表示的环境事务保存在TLS(Thread Local Storage)中,所以 环境事务是基于当前线程的。这就意味着,即使环境事务存在,通过异步调用的操作也不可能自动加入 到当前事务之中,因为在异步线程中感知不到环境事务的存在。在这种情况下,我们需要做的就是手工 将当前事务传递到另一个线程中,作为它的环境事务。通过依赖事务我们很容易实现这一点。
DependentTransaction通过Transaction的DependentClone方法创建,该方法具有一个 DependentCloneOption枚举类型的参数,体现了被依赖的事务再上尚未接受到依赖事务的通知(调用 Complete或者Rollback方法)得情况下,提交或者完成所采取的事务控制行为。DependentCloneOption 提供了两个选项,BlockCommitUntilComplete表示被依赖事务会一直等待接收到依赖事务的通知或者超 过事务设定的超时时限;而RollbackIfNotComplete则会直接将被依赖的事务回滚,并抛出 TransactionAbortedException异常。
1: [Serializable]
2: public class Transaction : IDisposable, ISerializable
3: {
4: //其他成员
5: public DependentTransaction DependentClone(DependentCloneOption cloneOption);
6: }
7: public enum DependentCloneOption
8: {
9: BlockCommitUntilComplete,
10: RollbackIfNotComplete
11: }