难道只有数据库连接才支持事务?答案肯定不是,因为COM+同样支持事务,一般的对象要支持事务需要怎样处理?
自行实现所有细节,比如说银行的提款机模拟,在Withdraw的代码中检查支取金额后的余额或者检查支取金额的大小是否超过当天限额限制,否则报错或退出当前Withdraw方法
这样做是行得通的,但是单个对象事务是简单的,如果两个对象一起控制呢,比如说转帐,必须符合金额支取的限制,同时目标帐户状态必须正常,如帐号存在,帐号没有停用等等,
通常要达到这样的要求就同时要求先检测两个帐号的行为是否符合规则了,比较麻烦
让我们回想一下,数据库的事务是咋样的!
一句话,无论前面做了什么,只要在事务中,而且一旦Rollback,即返回事务前的状态,而不需要每个动作都一起检查
恩,不错,在.Net里如何做到呢?
1. 必须有个类似于Transaction的对象,这个已经有了,就是System.Transaction.dll里的
System.Transactions.TransactionScope
2. 必须能够通知对象返回状态,恩,这个也好办,上面的DLL里有一个接口,System.Transactions.IEnlistmentNotification,只要实现它就行了,只有两个方法是要注意的,一个当然是Commit,一个是Rollback,Commit当然是要确认你的数据提交,Rollback是要你返回之前的状态
我做了一个提款机的例子,是单个账户的金额支取模拟,转帐嘛自己模仿一下吧
代码下载