查看文档,它说当事务处于挂起状态时(在开始事务之后和提交事务之前),Rollback方法可以抛出。
我似乎无法找到检查事务是否可以回滚的方法。也没有国家财产。
答案 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对象。如果是这样,您永远不需要发出回滚。如果您没有显式提交事务,那么一旦事务范围对象超出范围,它就会回滚。