0

我正在使用 EF5.0(数据库优先)并尝试更新复杂类型的“公司”实体,它包含“地址”实体作为导航属性。我从 UI 接收到 Company DTO 对象,然后使用 AutoMapper 将其映射到 Entity 对象并调用 objectContext.Save() 进行保存。

我面临的问题是,“公司”实体值正在保存,但“地址”实体没有。以下是每个对象的详细信息-

 public class CompanyDto
{
    public int Id { get; set; }
    public string Name { get; set; }
    public AddressDto Address { get; set; }
}

与 AddressDto 作为 -

public class AddressDto : IDto
{
    public int Id { get; set; }
    public string Street { get; set; }
    public string City { get; set; }
    public string PostCode { get; set; }
}

公司实体(由 EF 生成 - 数据库优先)

 public partial class tblCompany
{
    public tblCompany()
    {
        this.tblAddresses = new HashSet<tblAddress>();
    }

    public int ID { get; set; }
    public string CompanyName { get; set; }

    public virtual ICollection<tblAddress> tblAddresses { get; set; } //navigation property
}

与地址实体如下 -

  public partial class tblAddress
{
    public int ID { get; set; }
    public int CaseID { get; set; }
    public string AddressLine1 { get; set; }
    public string AddressLine2 { get; set; }
    public string City { get; set; }
    public string County { get; set; }
    public string PostCode { get; set; }

    public virtual tblCase tblCase { get; set; }
}

用于从 DTO 转换为实体的 AutoMapper 映射配置

  Mapper.CreateMap<CompanyDto, tblCase>()
            .ForMember(x => x.ID, opt => opt.MapFrom(cd => cd.Id))
            .ForMember(x => x.CompanyName, opt => opt.MapFrom(cd => cd.Name))
            .AfterMap((s, d) => d.tblAddresses.Add(new tblAddress
            {
                AddressLine1 = s.Address.Street,
                CaseID = s.Id,
                City = s.Address.City,
                PostCode = s.Address.PostCode
            }));



 public void Update(CompanyDto company)
    {
        //TO DO: check if AutoMapper could map address as well.

        var companyDao = Mapper.Map<CompanyDto, tblCase>(company);
        _companyRepository.Update(companyDao);
        _unitOfWork.Save();
    }

提前致谢

4

0 回答 0