gpt4 book ai didi

c# - DbContextTransaction 关于回滚的说明

转载 作者:行者123 更新时间:2023-12-03 06:17:43 25 4
gpt4 key购买 nike

这段代码:

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抛出它取决于具体的错误,您可以从中得出什么结论。网络和超时错误不允许您判断事务是否在存储中提交。

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

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

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

关于c# - DbContextTransaction 关于回滚的说明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27130529/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com