【发布时间】:2015-12-28 13:58:05
【问题描述】:
我正在尝试使用 AutoMapper 在 LLBLGen 实体和 DTO 之间创建映射。
我的 DTO 如下所示:
// Parent
public int Id { get; set; }
public List<Child> Children{ get; set; } // One to Many
// Child
public int Id { get; set; }
public int Parent { get; set; } // Foreign key to parent Id
ParentEntity 包含一个与 DTO 列表同名的 ChildCollection 和一个 Id(以及需要忽略的其他 LLBL 字段)。因此,当 ParentEntity 映射到 Parent DTO 时,它还应该将 ChildCollection 映射到子列表。
这是我目前得到的:
ParentEntity parentEntity = new ParentEntity(id);
AutoMapper.Mapper.CreateMap<ParentEntity, Parent>();
AutoMapper.Mapper.CreateMap<ChildCollection, List<Child>>();
var parent = AutoMapper.Mapper.Map<Parent>(parentEntity);
这会导致 Id 被映射,但 List 的计数为 0。
我怎样才能让它工作?
更新:
尝试与我之前的尝试相同,但手动映射子列表也会导致相同的问题:ID 被映射但列表为空。
Mapper.CreateMap<ParentEntity, Parent>()
.ForMember(dto => dto.Children, opt => opt.MapFrom(m => m.Children));
【问题讨论】:
-
请出示
ChildCollection类。其List属性的类型是什么?我认为最好提供实体和 DTO 的完整相关源代码来解决映射不起作用的原因。 -
我的问题中已经显示了 DTO。 ChildCollection 包含 ChildEntities,其中包含与 DTO 相同的字段以及更多与 LLBL 相关的资源。粘贴这些集合/实体的全部资源不会有用而且太多。如果您之前使用过 LLBL,那么您应该对这些类包含的内容有所了解。
标签: c# asp.net automapper dto llblgenpro