我有以下模型(和相应的DTO):
public class Link
{
public int Id {get; set;}
public int FirstLinkId {get; set;}
public int SecondLinkId {get; set;}
public virtual Link FirstLink {get; set;}
public virtual Link SecondLInk {get; set;}
}
public class OtherObject
{
public int Id {get; set;}
public int LinkId {get; set;}
public string Name {get; set;}
public virtual Link Link {get; set;}
}
在我的场景中,我可以有一个Link
对象,其中FirstLink
和/或SecondLink
可以为null,对其他对象的引用或对同一对象的引用。
现在我想使用EF从数据库加载OtherObject
实体。我加载实体本身以及与之关联的Link
对象。这完全由EF完成。
在这种特殊情况下,FirstLink
和SecondLink
都与Link
相同,因此,当从模型自动化到dto时,它只会继续映射到遗忘。
我的映射是:
Mapper.CreateMap<OtherObject, OtherObjectDto>().Bidirectional()
.ForMember(model => model.LinkId, option => option.Ignore());
其中Bidirectional()是此扩展名:
public static IMappingExpression<TDestination, TSource> Bidirectional<TSource, TDestination>(this IMappingExpression<TSource, TDestination> expression)
{
return Mapper.CreateMap<TDestination, TSource>();
}
在这种情况下,有没有办法告诉Automapper不要在树下进一步映射?
答案 0 :(得分:6)
我处理这个问题的方法是为孩子们创建单独的DTO对象:
public class Employee
{
public int Id {get; set;}
public string Name { get; set; }
public Employee Supervisor {get; set; }
}
public class EmployeeDto {
public int Id {get; set;}
public string Name { get; set; }
public SupervisorDto Supervisor { get; set; }
public class SupervisorDto {
public int Id {get; set;}
public string Name { get; set; }
}
}
Mapper.CreateMap<Employee, EmployeeDto>();
Mapper.CreateMap<Employee, EmployeeDto.SupervisorDto>();
不要让你的DTO递归/自我指涉。在你的结构中明确你想要它有多深。
EF不能做递归连接,你只做一个级别,所以不要让你的DTO与无限深层的关系疯狂。要明确。