如何使用AutoMapper映射相关数据

问题描述 投票:0回答:1

我正在尝试使用 AutoMapper 将三个实体模型映射到一个视图模型。最终输出应该是一个递归类别树,其中包含类别中的产品。类别树正在工作,但视图模型的

Products
属性是
null
。我的查询返回类别和产品,所以我认为映射不知道如何将产品映射到视图模型。

我的实体模型:

public class ProductCategory
{
    public int Id { get; set; }
    public int SortOrder { get; set; }
    public string Title { get; set; }
    [ForeignKey(nameof(ParentCategory))]
    public int? ParentId { get; set; }
    // Nav.props:
    public ProductCategory ParentCategory { get; set; }
    public ICollection<ProductCategory> Children { get; set; }
    public List<ProductInCategory> ProductInCategory { get; set; }
}

public class ProductInCategory
{
    public int Id { get; set; }
    public int ProductId { get; set; }
    public int SortOrder { get; set; }
    public int ProductCategoryId { get; set; }
    public bool IsProductCategoryFrontPage { get; set; }
    // Nav.props.
    public Product Product { get; set; }
    public ProductCategory ProductCategory { get; set; }
}

public class Product
{
    public int Id { get; set; }
    public string Title { get; set; }
    public string Info { get; set; }
    public decimal Price { get; set; }
    // Nav.prop:
    public List<ProductInCategory> InCategories { get; set; }
}

我的视图模型:

public class ViewModelProductCategory
{
    public int Id { get; set; }
    public int? ParentId { get; set; }
    public string Title { get; set; }
    public int SortOrder { get; set; }

    public string ProductCountInfo
    {
        get
        {
            return Products != null && Products.Any() ? Products.Count().ToString() : "0";
        }
    }

    public ViewModelProductCategory ParentCategory { get; set; }
    public IEnumerable<ViewModelProductCategory> Children { get; set; }
    public IEnumerable<ViewModelProduct> Products { get; set; }
}

我尝试过这种映射(映射类别,但没有产品):

CreateMap<ProductCategory, ViewModelProductCategory>();
CreateMap<ViewModelProductCategory, ProductCategory>();

我尝试过这种映射(映射类别,但没有产品):

CreateMap<ProductCategory, ViewModelProductCategory>()
    .ForMember(dto => dto.Id, opt => opt.MapFrom(src => src.Id))
    .ForMember(dto => dto.ParentId, opt => opt.MapFrom(src => src.ParentId))
    .ForMember(dto => dto.Title, opt => opt.MapFrom(src => src.Title))
    .ForMember(dto => dto.SortOrder, opt => opt.MapFrom(src => src.SortOrder))
    .ForMember(dto => dto.Children, opt => opt.MapFrom(src => src.Children))
    .ForMember(dto => dto.Products, opt => opt.MapFrom(src => src.ProductInCategory));
c# entity-framework-core automapper
1个回答
5
投票

看起来您想跳过视图模型中的连接(链接)实体。

为此,首先创建从

Product
ViewModelProduct
的映射,然后使用将
ProductCategory.ProductInCategory
转换为
ViewModelProductCategory.Products
的投影定义从
List<ProductInCategory>
IEnumerable<Product>
的映射。 AutoMapper 会小心地将
IEnumerable<Product>
转换为
List<ViewModelProduct>
,就像您查询
Products
一样:

CreateMap<Product, ViewModelProduct>();

CreateMap<ProductCategory, ViewModelProductCategory>()
    .ForMember(dst => dst.Products, opt => opt.MapFrom(
        src => src.ProductInCategory.Select(pc => pc.Product)));
© www.soinside.com 2019 - 2024. All rights reserved.