繁体   English   中英

EF Core 相关数据为 null with AutoMapper

[英]EF Core related data is null with AutoMapper

在我的应用中,一个案例可以有很多公司。

我的模型:

public class Case
{
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public Guid Id { get; set; }
    public string Name { get; set; }
    public IList<CaseCompany> CaseCompanies { get; set; }
}

public class CaseInput
{
    public Guid Id { get; set; }
    [Required]
    public string Name { get; set; }
    public IList<CaseCompanyInput> CaseCompanyInputs { get; set; }
}

public class Company
{
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public Guid Id { get; set; }
    public string Name { get; set; }
}

public class CompanyInput
{
    public Guid Id { get; set; }
    [Required]
    public string Name { get; set; }
}

public class CaseCompany
{
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public Guid Id { get; set; }
    public Guid CaseId { get; set; }
    public Guid CompanyId { get; set; }
    public class Case Case { get; set; }
    public class Company Company { get; set; }
}

public class CaseCompanyInput
{
    public Guid Id { get; set; }
    public Guid CaseId { get; set; }
    public Guid CompanyId { get; set; }
    public class CaseInput CaseInput { get; set; }
    public class CompanyInput CompanyInput { get; set; }
}

AutoMapperProfiles.cs:

// In Startup.cs: services.AddAutoMapper(typeof(AutoMapperProfiles));

public class AutoMapperProfiles : Profile
{
    public AutoMapperProfiles()
    {
        CreateMap<Case, CaseInput>().ReverseMap();
        CreateMap<CaseCompany, CaseCompanyInput>().ReverseMap();
        CreateMap<Company, CompanyInput>().ReverseMap();
    }
}

编辑案例.cs:

private readonly DBContext _dbContext;
private readonly IMapper _mapper;

[BindProperty]
public CaseInput CaseInput { get; set; }

public EditCase(DBContext dbContext, IMapper mapper)
{
    _dbContext = dbContext;
    _mapper = mapper;
}

public async Task<IActionResult> OnGetAsync(Guid caseId)
{
    var getCase = await _dbContext.Cases.Include(x => x.CaseCompanies).ThenInclude(x => x.Company).FirstOrDefaultAsync(x => x.Id == caseId);
    CaseInput = _mapper.Map<CaseInput>(getCase);

    Console.WriteLine(getCase.CaseCompanies[0].Company.Name) // gets the company name
    Console.WriteLine(CaseInput.CaseCompanyInputs[0].CompanyInput.Name) // CaseInput.Name is not null but CaseCompanyInputs is null

    return Page();

}

我也试过:

CaseInput = await _dbContext.Cases.ProjectTo<CaseInput>(_mapper.ConfigurationProvider).FirstOrDefaultAsync(x => x.Id == caseId);

CaseInput = await _dbContext.Cases.Include(x => x.CaseCompanies).ThenInclude(x => x.Company).ProjectTo<CaseInput>(_mapper.ConfigurationProvider).FirstOrDefaultAsync(x => x.Id == caseId);

结果相同: CaseCompanyInputs为 null。

我最好的猜测是输入模型的关系有错误,但我就是看不到。 我相信我已经遵循命名约定来使关系正确。

任何帮助,将不胜感激。

要使自动映射起作用,您必须将您的目标属性名称重命名为与源属性名称相同

public class CaseInput
{
    public Guid Id { get; set; }
    public string Name { get; set; }
    //public IList<CaseCompanyInput> CaseCompanyInputs { get; set; }
    public IList<CaseCompanyInput> CaseCompanies { get; set; }
}

public class CaseCompanyInput
{
    public Guid Id { get; set; }
    public Guid CaseId { get; set; }
    public Guid CompanyId { get; set; }
    //public CaseInput CaseInput { get; set; }
    public CaseInput Case { get; set; }
    //public CompanyInput CompanyInput { get; set; }
    public CompanyInput Company { get; set; }
}

如果您不想更改属性名称,请将您的配置更改为以下内容。

CreateMap<Case, CaseInput>()
    .ForMember(dest => dest.CaseCompanyInputs, opt => opt.MapFrom(src => src.CaseCompanies));

CreateMap<CaseCompany, CaseCompanyInput>()
    .ForMember(dest => dest.CaseInput, opt => opt.MapFrom(src => src.Case))
    .ForMember(dest => dest.CompanyInput, opt => opt.MapFrom(src => src.Company));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM