public class Foo{ public int ID { get; set; } public virtual ICollection<bar> bars { get; set; }}public class bar{ public int ID { get; set; } public int FooID { get; set; } public virtual Foo Foo { get; set; } public string name { get; set; } public int SortOrder { get; set; }}public class FooDto{ public IEnumerable<barDto> bars { get; set; }}public class barDto{ public string name { get; set; } public int SortOrder { get; set; }}
我的映射看起来像:
mapper.CreateMap<Foo,FooDto>();mapper.CreateMap<bar,barDto>();
到现在为止还挺好.我可以从我的上下文和项目中获取实体到DTO:
var foos = context.Foos.Project().To<FooDto>();
然而,我无法使用这种方法,它是通过其在Iqueryable中的SortOrder来对bars进行排序的.
如果我尝试:
mapper.CreateMap<Foo,FooDto>() .ForMember( x => x.bars opt => opt.MapFrom(src => src.bars.OrderBy(x => x.sortOrder)));mapper.CreateMap<bar,barDto>();var foos = context.Foos.Project().To<FooDto>();
我有一个例外:
system.invalIDOperationException: Sequence contains no elements at System.linq.Enumerable.First[TSource](IEnumerable`1 source) at autoMapper.MapPingEngine.CreateMapExpression(Type typeIn,Type typeOut) ...
这似乎与https://github.com/AutoMapper/AutoMapper/issues/159有关 – 虽然我已经在使用一个复杂的类型作为子集合.我猜CreateMapExpression不支持OrderBy的子集合?
如果我没有使用.Project().To(),那么我可以轻松地排序孩子集合:
var model = context.Foos.Select(x => new FooDto(){ bars = x.bars.OrderBy(y => y.sortOrder)});
但是我必须重复映射,无论我想要使用它,都击败了使用autoMapper的目的.
奇怪的是: –
1)我可以对孩子集合执行其他(更复杂的) *** 作,并将这些 *** 作放在我的父DTO中没有问题:
mapper.CreateMap<Foo,FooDto>() .ForMember( x => x.AllbarsHaveAname,opt => opt.MapFrom(src => src.bars.All(x => x.name != null)));
2)我可以Mapper.Map< FooDto>(foo);记忆力好,它会排序酒吧没问题.
可以在Iqueryable级别对子集合进行排序,同时仍然使用.Project().To()?
解决方法 结束修改autoMapper源代码以支持此方案.希望提议的修复将被接受,但同时您可以看到详细信息:https://github.com/AutoMapper/AutoMapper/pull/327
总结以上是内存溢出为你收集整理的c# – AutoMapper Project().To()和排序子集合全部内容,希望文章能够帮你解决c# – AutoMapper Project().To()和排序子集合所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)