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

时间:2019-02-13 17:49:24

标签: c# postgresql entity-framework automapper

我尝试构建一些小型聊天应用程序,首先,我尝试获取已创建的聊天室列表,但是当我从数据库中获取数据并尝试通过Queryable Extensions映射它时:IQueariable.ProjectionTo()我收到一个自定义字段的错误。我使用PostgreSQL,Automapper和EF内核。

如果我第一次序列化此列表,它是有效的,但对我来说似乎很脏:两个操作代替一个。 例如,这可以正常工作:

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

顺便说一句,如果我在Automapper配置文件中忽略Name道具,它也可以工作!甚至是派生集合!

另一方面,我认为它存在于不同类型的字段中的问题(我很少使用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;

但仍然是相同的结果。

谢谢您的帮助!

1 个答案:

答案 0 :(得分:0)

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