ProjectionTo返回ArgumentException:参数类型不匹配

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

我尝试构建一些小型聊天应用程序,首先,我尝试获取创建的聊天室列表,但是当我从数据库中获取数据并尝试通过可查询扩展名来映射时:IQueariable.ProjectionTo()我得到了自定义字段出错。我使用PostgreSQL,Automapper,EF核心。

如果我首先序列化这个列表,它正在工作,但它看起来很脏我:两个操作而不是一个。例如,这工作正常:

var rooms = await _context.Set<Chat>()
                .ToListAsync()
                ;
return Mapper.Map<List<ChatDto>>(rooms);

顺便说一下,如果我忽略Automapper配置文件中的Name props,它的作品也是如此!甚至派生的收藏!

另一方面,我认为它在不同类型的字段中的问题(我很少使用postgre),但如果我改变映射,像这样:

CreateMap<Chat, ChatDto>()
                .ForMember(x => x.Name, opt => opt.MapFrom(x => x.Id.ToString()));

我得到了相同的错误ArgumentException:参数类型不匹配,但id映射正常。

它的返回异常:

var test = _context.Set<Chat>()
                    .ProjectTo<ChatDto>()
                    .ToListAsync()
                ;

stacktrace的一部分:

System.ArgumentException: Argument types do not match
   at System.Linq.Expressions.Expression.Bind(MemberInfo member, Expression expression)
   at AutoMapper.QueryableExtensions.Impl.EnumerableExpressionBinder.BindEnumerableExpression(IConfigurationProvider configuration, PropertyMap propertyMap, ExpressionRequest request, ExpressionResolutionResult result, IDictionary`2 typePairCount, LetPropertyMaps letPropertyMaps) in C:\projects\automapper\src\AutoMapper\QueryableExtensions\Impl\EnumerableExpressionBinder.cs:line 37
   at AutoMapper.QueryableExtensions.Impl.EnumerableExpressionBinder.Build(IConfigurationProvider configuration, PropertyMap propertyMap, TypeMap propertyTypeMap, ExpressionRequest request, ExpressionResolutionResult result, IDictionary`2 typePairCount, LetPropertyMaps letPropertyMaps) in C:\projects\automapper\src\AutoMapper\QueryableExtensions\Impl\EnumerableExpressionBinder.cs:line 16
   at AutoMapper.QueryableExtensions.ExpressionBuilder.<>c__DisplayClass17_0.<CreateMemberBindings>g__CreateMemberBinding|0(PropertyMap propertyMap) in C:\projects\automapper\src\AutoMapper\QueryableExtensions\ExpressionBuilder.cs:line 290

ChatEntity:

public class Chat : HasId<Guid>
    {
        public string Name { get; set; }

        public ICollection<ChatMember> ChatMembers { get; } = new List<ChatMember>();
    }

DTO:

public class ChatDto
    {
        public Guid Id { get; set; }

        public string Name { get; set; }

        public ChatMemberDto[] ChatMembers { get; set; }
    }

制图:

CreateMap<Chat, ChatDto>()
                .ForMember(x => x.Name, opt => opt.MapFrom(x => x.Name));

我清楚地指出了这个领域的映射,当然,这不是必需的

我尝试检查执行计划,如下所示:

var test = _context.Set<Chat>()
                .ProjectTo<ChatDto>()
                .Expression;

但仍然是同样的结果。

谢谢您的帮助!

c# postgresql entity-framework automapper
1个回答
0
投票

如果您不知道,AutoMapper会自动映射具有相同名称的参数。我怀疑在这里发生的是,当映射到Dto.ChatMembers上的ChatMemberDto []时,ChatEntity.ChatMembers(ICollection)存在冲突。

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