.NET 中的事务回滚操纵

当一个程序要对数据库进行查询操作(增、删、改),可能会有各种各样的原因让查询不成功,也许是内存,也许是网速等。

这时,数据库的数据应该怎么办,对!应该恢复到查询之前的样子,特别是多表的操作,这点显得更加重要了,这回就要用到事务的回滚了,下面仅说一下个人的用法:

一、准备:在项目中引用System.Transactions,同时using System.Transactions;,这样,就可以使用.NET里的事务类了;

 

 

二、使用:

  1. using (TransactionScope t = new TransactionScope())
  2.               {
  3.  
  4.                   //对数据库的相关操作,
  5.  
  6.                   t.Complete();
  7.               }

下面这行是Castle 的事务回滚

 

  1. using (TransactionScope tran = new TransactionScope())
  2.              {
  3.                  try
  4.                  {
  5.                      tran.VoteCommit();
  6.                  }
  7.                  catch
  8.                  {
  9.                      tran.VoteRollBack();
  10.                  }
  11.              }

就这样简单,当{}中的数据提交不成功的话,数据库的数据会恢复到提交之前的样子。
哈哈,.NET就是好哇,把什么东西都封得这样完美了,哎,同时感觉自己像个傻瓜一样,,,
对了,还有一点,做好前两点之后,还要开启一个服务
Distributed Transaction Coordinator,就全部OK啦~~~

 

 

posted @ 2009-07-12 21:56  芋头  阅读(410)  评论(0编辑  收藏  举报