gpt4 book ai didi

c# - DBTransaction 回滚抛出

转载 作者:行者123 更新时间:2023-12-02 17:55:11 24 4
gpt4 key购买 nike

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

我似乎找不到一种方法来检查事务是否可以回滚。也没有国有属性(property)。

最佳答案

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

其余时间,虽然很难看,但我通常将回滚包装在空的 try/catch block 中,因为它几乎总是位于具有更有意义的异常的 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.
}

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

关于c# - DBTransaction 回滚抛出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2826861/

24 4 0