【发布时间】:2020-08-16 03:29:19
【问题描述】:
我最近在 .NET Core 3.1 中创建了一个 Web API 项目,并使用 code first 方法实现了 Entity Framework Core。我的每个模型都像这样引用其他模型:
public class Condominium
{
public int Id { get; set; }
public Address Address { get; set; }
public int Levels { get; set; }
public string Description { get; set; }
public CondominiumType CondominiumType { get; set; }
}
正如您在本示例中所见,我指的是 Address 和 CondominiumType,而没有使用参考 ID。 Entity Framework 会在数据库迁移时创建对应的外键。
当我必须添加带有新地址的新公寓时,这非常有效,但是当我想添加 现有 地址或公寓类型时遇到问题。
当我将一个带有已添加到数据库的 Id 的对象传递给上下文时,程序会抛出异常,因为我违反了表的 UNIQUE 约束。我知道我可以通过添加类似这样的引用键来解决这个问题
public class Condominium
{
public int Id { get; set; }
public int AddressId { get; set; }
public Address Address { get; set; }
public int Levels { get; set; }
public string Description { get; set; }
public int CondominiumTypeId { get; set; }
public CondominiumType CondominiumType { get; set; }
}
但我想知道哪种方法是解决此类案件的正确方法。 ¿是否可以在不重写我的类的情况下添加现有对象?
在业务层中,我正在传递数据,抛出一个 UnitOfWork 模式:
public async Task<bool> AddCondominium(int AgencyId,CondominiumDTO newCondominium)
{
var condominium = _mapper.Map<Condominium>(newCondominium);
condominium.ConsortiumAdministrationAgency = new ConsortiumAdministrationAgency() { Id = AgencyId };
_unitOfWork.Addresses.Add(condominium.Address);
_unitOfWork.Condominiums.Add(condominium);
return await _unitOfWork.CompleteAsync();
}
【问题讨论】:
-
您要问的是如何解决问题的症状。相反,您应该问,如何解决问题的原因。正确的方法是从数据库中检索“重复”实体,更新任何已更改的属性,然后保存更改。
-
我认为这个问题与您的课程无关,而是您在上下文中访问实体的方式。您能否在访问导致问题的上下文的位置添加代码。如上所述,您应该在上下文中引用现有实体,然后将其分配给同一上下文中的新实体。然后,当您保存更改时,EF 知道您引用的是现有实体而不是尝试添加新实体。
-
@Selthien 这是服务层的代码: public async Task
AddCondominium(int AgencyId,CondominiumDTO newCondominium) { var condominium = _mapper.Map (newCondominium); condominium.ConsortiumAdministrationAgency = new ConsortiumAdministrationAgency() { Id = AgencyId }; _unitOfWork.Addresses.Add(condominium.Address); _unitOfWork.Condominiums.Add(condominium);返回等待 _unitOfWork.CompleteAsync(); } -
对于新条目,您的唯一 (id) 应该是自动生成的(不是您自己设置的)。要更新条目,您应该通过 id 获取它并修改其他道具并保存。此外,这可能是您的课程的问题。提供更多信息以寻求帮助。
标签: c# asp.net-core entity-framework-core code-first