工作单元更新问题:实体已经在跟踪另一个实例

问题描述

我的 UOW 模式 实现有问题(我的 UOW 使用存储库模式)。我将尝试用两个简单的类来解释我的项目结构。 我有人和车,(一对多 - 一对一)。

[Table("Person")]
public class Person
{
    public int id{ get; set; }
    public string name{ get; set; }
    public IList<Car> cars_owned{ get; set; }

}

[Table("Car")]
public class Car
{
    public int id{ get; set; }
    public Person owner{ get; set; }
}

在我的 CarServiceImplementation 中,我想实现我的 AddUpdateCar(),以便在“人”不存在时添加它或更新它。

这是我的实际实现:

public async Task<bool> addUpdateCar(AddUpdateCarModel model)
        {
            var car = await unitOfWork.CarRepository.GetByID(model.car_id);
            var person = await unitOfWork.PersonRepository.GetByID(model.person.id);
            if (person == null)
            {
                unitOfWork.PersonRepository.Insert(model.person);
            }
            else
            {
                unitOfWork.PersonRepository.Update(model.person);
            }

            car.owner = model.person;
            unitOfWork.CarRepository.Update(car);
            unitOfWork.Save();
            return true;
        }

这种实现表示:无法跟踪实体类型“Person”的实例,因为已经跟踪了另一个具有相同 {'id'} 键值的实例。

我也尝试过不同的方法,但我还有其他问题。

实现这种方法的正确方法是什么?

编辑 1:

public void Update(Person p)
{
    context.Entry(p).State = EntityState.Modified;
}

public async Task<Person> GetByID(int id)
        {
            return await context.person.FindAsync(id);
        }

解决方法

由于您使用的是工作单元,因此最简单的方法是向 PersonRepository 添加一个新方法

public void InsertOrUpdate(Person p)
{
    var existedPerson = GetByID(p.id);
    if (existedPerson != null) 
        context.Entry(existedPerson).CurrentValues.SetValues(p);
    else Insert(p);
}