Skip to main content
 首页 » 编程设计

c#之DbContextTransaction 关于回滚的说明

2024年06月03日11sharpest

这段代码:

using(var context = this.contextFactory.Create()) // creates a context 
using(var transaction = context.Database.BeginTransaction()) // starts a transaction 
{ 
    try 
    { 
        await context.SaveChangesAsync(); // Save my changes 
 
        transaction.Commit(); // Commit my changes 
    } 
    catch(Exception) 
    { 
        transaction.RollBack(); // Rollback my changes 
    } 
} 

我这样说是否正确,如果 transaction.Commit()抛出错误,然后 transaction会被回滚吗?

不仅仅是在创建实体或将实体添加到 DbSet<> 的场景中。我认为我是正确的,但只是想确定一下。

请您参考如下方法:

事务要么提交,要么回滚。没有中间地带。

如果Commit抛出它取决于具体的错误,您可以从中得出什么结论。网络和超时错误不允许您判断事务是否在存储中提交。

您不需要显式回滚。正如我所说,没有中间地带。如果事务不提交,则肯定会回滚。我不知道为什么网络上有这么多人决定明确回滚。也许,您刚刚看到了错误的示例代码。标准模式是在发生错误时不执行任何操作。

错误会冒泡,导致回滚,并最终在可以采取措施的地方进行处理。

您正在接受异常。非常危险。