DBTransaction Rollback抛出

时间:2010-05-13 12:52:24

标签: c# .net transactions

查看文档,它说当事务处于挂起状态时(在开始事务之后和提交事务之前),Rollback方法可以抛出。

我似乎无法找到检查事务是否可以回滚的方法。也没有国家财产。

2 个答案:

答案 0 :(得分:5)

理想情况下,只需使用“using”语句包装事务或使用TransactionScope对象,如果抛出异常或在事务超出范围之前未提交事务,则会自动回滚。

剩下的时间,虽然它很丑,我通常将我的回滚包装在一个空的try / catch块中,因为它几乎总是在一个具有更有意义的异常的catch处理程序中。我们的想法是,如果可以,我们只想回滚,但如果我们不能(因为任何数字不可预测的原因),我们不想开始抛出新的异常,因为只要事务没有提交,事务就会被回滚无论如何。你仍然需要尝试正确清理所以它不需要等待垃圾收集器,但如果你不能,那么回滚不是真正的问题。

try
{
  SqlTransaction trans = connection.BeginTransaction();
  ///blah blah blah
}
catch(Exception theExceptionICareAbout)
{
  try
  {
    if(trans != null)
    {
      trans.Rollback();
    }
  }
  catch {}
  throw;  //re-throws the meaningful exception.
}

注意:不要明确地重新抛出异常(即“throw theExceptionICareAbout”),因为这将重新创建堆栈跟踪。相反,只需使用“throw”,它将继续现有的异常堆栈。

答案 1 :(得分:0)

您是否在c#代码中使用了TransactionScope对象。如果是这样,您永远不需要发出回滚。如果您没有显式提交事务,那么一旦事务范围对象超出范围,它就会回滚。