【问题标题】:Does EF Core support TransactionScope?EF Core 是否支持 TransactionScope?
【发布时间】:2021-03-07 00:23:26
【问题描述】:

我有 .NET Core 3.1EntityFrameworkCore 3.1.8

在一个命令(将数据写入数据库)中,我多次使用SaveChanges() 方法。因此,我决定将所有这些事务化并像这样使用TransactionScope()

using (var scope = new TransactionScope())
{
}

这是正确的方法吗?这会正常工作吗?

注意:我有一个 DbContext

【问题讨论】:

  • 应该是嵌套事务吧?我更喜欢根本不使用 TransactionScope,它与分布式事务更相关。

标签: entity-framework-core asp.net-core-3.1 transactionscope


【解决方案1】:

是的,TransactionScope 很可能适合您。作为个人建议,我会改用DbContext.Database.BeginTransaction()

这样做的原因是因为TransactionScope 必须由您正在使用的库实现。一般来说,关系数据库的 SDK 应该支持TransactionScope(我知道 Microsoft.Data.SqlClient for SQL Server 支持,不确定其他数据库)。

来源:https://docs.microsoft.com/en-us/ef/core/saving/transactions#using-systemtransactions

【讨论】:

  • 根本不是一个答案——这个问题对于它的要求非常明确,这完全被忽略了。年龄的 TransactionScope 也有特殊优化(仅针对一个来源)。
  • 正确。我会相应地修改我的答案。
猜你喜欢
  • 1970-01-01
  • 2020-05-05
  • 1970-01-01
  • 1970-01-01
  • 2017-11-09
  • 2017-05-22
  • 1970-01-01
  • 2017-08-24
  • 1970-01-01
相关资源
最近更新 更多