gpt4 book ai didi

c# - Entity Framework 事务错误

转载 作者:行者123 更新时间:2023-12-03 20:34:03 26 4
gpt4 key购买 nike

我正在使用 Entity Framework ,并且有几种使用事务的方法。我收到此错误:连接已经在一个事务中,不能参与另一个事务。 EntityClient 不支持并行事务。
我有多种方法取决于“MethodB”,如下面的代码示例:

public void MethodA(){
using (var tran = Db.Database.BeginTransaction()){
MethodB();
var tableARecord = new TableARecord();
try
{
_context.TableAs.Add(tableARecord)
Db.SaveChanges();
}
catch (Exception excp)
{
tran.Rollback();
throw;
}
}
}

public void MethodC(){
using (var tran = Db.Database.BeginTransaction()){
MethodB();
//do something else
}
}

public int MethodB(){
int ret = 0
//exception happens when starting the transaction below
using (var tran = Db.Database.BeginTransaction()){
//do something else
}
return ret;
}

最佳答案

在打开一个新的事务之前,你需要提交前一个,所以你不应该在前一个里面打开一个新的事务。

public void MethodA(){
using (var tran = Db.Database.BeginTransaction()){
try
{
MethodB();
var tableARecord = new TableARecord();
_context.TableAs.Add(tableARecord)
Db.SaveChanges();
}
catch (Exception excp)
{
tran.Rollback();
throw;
}
}
}

public int MethodB(){
int ret = 0
//exception happens when starting the transaction below
// The transaction is already open, you should not open a new one.

//do something else
return ret;
}

但是,你这样做的方式是一种反模式。打开事务时未进行的每个“保存更改”都将是单个事务。

您应该做的是在您的业务逻辑中开始您的事务,并在同一级别提交它。
// Business Logic :
var transaction = Db.Database.BeginTransaction())
try {
_Repository.MethodA();
_Repository.MethodB();
transaction.Commit();
}
catch(){
transaction.Rollback();
}


//Repository :

public void MethodA(){
var tableARecord = new TableARecord();
_context.TableAs.Add(tableARecord)
Db.SaveChanges();
}

public void MethodA(){
// Just do some other stuff
Db.SaveChanges();
}

关于c# - Entity Framework 事务错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36844854/

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