gpt4 book ai didi

entity-framework - 如何在两个 dbContext 中与 EF6 共享事务?

转载 作者:行者123 更新时间:2023-12-04 08:57:25 27 4
gpt4 key购买 nike

我正在使用 EF6,我知道有两种方法可以使用事务,BeginTransaction 和 UseTransaction。

我过去只使用一个 dbContext,但在我的情况下,我需要使用辅助 dbContext,并且我需要第二个 dbContext 使用与主 dbContext 相同的事务。我尝试使用此代码:

using(Entities miDbContext = new Entities())
{
using (DbContextTransaction miTransaccion = miDbContext.Database.BeginTransaction())
{
Entities miDbContext2 = new Entities();
miDbContext2.DataBase.UseTransaction(miTransaccion);
}
}

但是我在 UseTransaction 中得到一个错误,因为 miTrasaccion 不是正确的类型。

我想知道如何在两个 dbContext 之间共享相同的事务。

谢谢。

最佳答案

您需要先将 miDbContext 的连接传递给 miDbContext2。
试试下面的代码。它应该工作。

Entities miDbContext2 = new Entities(miDbContext.Database.Connection, false);
miDbContext2.DataBase.UseTransaction(miTransaccion.UnderlyingTransaction);

关于entity-framework - 如何在两个 dbContext 中与 EF6 共享事务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20382070/

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