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

Edu*_* M 5 c# postgresql entity-framework automapper

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

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

var rooms = await _context.Set<Chat>()
                .ToListAsync()
                ;
return Mapper.Map<List<ChatDto>>(rooms);
Run Code Online (Sandbox Code Playgroud)

顺便说一句,如果我忽略 Automapper 配置文件中的 Name 道具,它也可以工作!连派生收藏!

另一方面,我认为它在不同类型的字段中存在问题(我很少使用 postgre),但是如果我更改映射,如下所示:

CreateMap<Chat, ChatDto>()
                .ForMember(x => x.Name, opt => opt.MapFrom(x => x.Id.ToString()));
Run Code Online (Sandbox Code Playgroud)

我得到了同样的错误 ArgumentException: Argument types do not match,但 id map 很好。

它的返回异常:

var test = _context.Set<Chat>()
                    .ProjectTo<ChatDto>()
                    .ToListAsync()
                ;
Run Code Online (Sandbox Code Playgroud)

堆栈跟踪的一部分:

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
Run Code Online (Sandbox Code Playgroud)

聊天实体:

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

        public ICollection<ChatMember> ChatMembers { get; } = new List<ChatMember>();
    }
Run Code Online (Sandbox Code Playgroud)

到:

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

        public string Name { get; set; }

        public ChatMemberDto[] ChatMembers { get; set; }
    }
Run Code Online (Sandbox Code Playgroud)

映射:

CreateMap<Chat, ChatDto>()
                .ForMember(x => x.Name, opt => opt.MapFrom(x => x.Name));
Run Code Online (Sandbox Code Playgroud)

我清楚地指出了这个字段的映射,虽然这不是必需的,当然

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

var test = _context.Set<Chat>()
                .ProjectTo<ChatDto>()
                .Expression;
Run Code Online (Sandbox Code Playgroud)

但仍然是相同的结果。

感谢您的帮助!

And*_*ias 1

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

  • 无论它在做什么,如果它不告诉我哪个参数不匹配,那么它都是毫无用处的:-( (8认同)