Automapper 问题:递归投影 LinqToSql Stackoverflow 异常

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

enter image description here

使用上述 LinqToSql 实体类并尝试映射到类似名称的 DTO 对象会引发 Stackoverflow 异常。我已经阅读了周围的内容,这似乎是 CriteriaGroup 对象的子/父关系的问题。有人有什么建议吗?

用于调用此代码的代码:

var mappedDtos = this.configurationRepository
                        .GetAll()
                        .Project()
                        .To<CriteriaGroupDto>();

GetAll() 的位置是:

public override IQueryable<TEntity> GetAll()
{
    return this.Table.AsQueryable();
}    

我为此制作的映射代码是:

/// <summary>
/// The criteria profile.
/// </summary>
public class CriteriaProfile : Profile
{
    /// <summary>
    /// The configure.
    /// </summary>
    protected override void Configure()
    {
        Mapper.CreateMap<CriteriaGroup, CriteriaGroupDto>()
                .ForMember(dest => dest.Groups, opt => opt.MapFrom(src => src.Children))
                .ForMember(dest => dest.Parent, opt => opt.MapFrom(src => src.Parent))
                .ForMember(dest => dest.Criteria, opt => opt.MapFrom(src => src.CriteriaConfigs));

        Mapper.CreateMap<CriteriaConfig, CriteriaConfigDto>()
            .Include<RatingConfig, CriteriaConfigDto>()
            .Include<CountryConfig, CriteriaConfigDto>()
            .Include<TimescaleConfig, CriteriaConfigDto>()
            .ForMember(dest => dest.DefaultValue, opt => opt.UseValue(default(object)))
            .ForMember(dest => dest.DataType, opt => opt.Ignore())
            .ForMember(dest => dest.ElementId, opt => opt.MapFrom(src => src.Id))
            .ForMember(dest => dest.Options, opt => opt.Ignore());

        Mapper.CreateMap<RatingConfig, CriteriaConfigDto>()
            .ForMember(dest => dest.JoinOperators, opt => opt.MapFrom(src => src.JoinOperators))
            .ForMember(dest => dest.OptionOperators, opt => opt.MapFrom(src => src.Operators));

        Mapper.CreateMap<CountryConfig, CriteriaConfigDto>()
            .ForMember(dest => dest.JoinOperators, opt => opt.MapFrom(src => src.JoinOperators))
            .ForMember(dest => dest.OptionOperators, opt => opt.MapFrom(src => src.Operators));

        Mapper.CreateMap<TimescaleConfig, CriteriaConfigDto>()
            .ForMember(dest => dest.JoinOperators, opt => opt.MapFrom(src => src.JoinOperators))
            .ForMember(dest => dest.OptionOperators, opt => opt.MapFrom(src => src.Operators));

        base.Configure();
    }
}

派生类中的附加映射是由于:(EG)

/// <summary>
/// The rating config.
/// </summary>
public partial class RatingConfig
{
    /// <summary>
    /// Gets the operators.
    /// </summary>
    public IEnumerable<RatingOperator> Operators
    {
        get
        {
            return Enumeration.GetAll<RatingOperator>();
        }
    }

    /// <summary>
    /// Gets the join operators.
    /// </summary>
    public IEnumerable<RuleJoinOperator> JoinOperators
    {
        get
        {
            return Enumeration.GetAll<RuleJoinOperator>();
        }
    }
}
c# linq-to-sql automapper
1个回答
0
投票

我的答案有点晚了,但根据我今天所知道的,我根本不会使用 AutoMapper。最终看来,它的工作量并不比手动映射少,而且我们使用的方式,我认为我们根本不需要映射。我们也可以在每种情况下简单地使用相同的类 - 如果不是所有字段都需要所有字段,这并不重要......

© www.soinside.com 2019 - 2024. All rights reserved.