ProjectionTo return ArgumentException: типы аргументов не совпадают - PullRequest
0 голосов
/ 13 февраля 2019

Я пытаюсь создать небольшое приложение чата, в первую очередь я пытался получить список созданных комнат чата, но когда я выбираю данные из БД и пытаюсь сопоставить их с помощью Queryable Extensions: IQueariable.ProjectionTo ()Я получил ошибку с пользовательским полем.Я использую PostgreSQL, Automapper, EF core.

Если я впервые сериализую этот список, он работает, но для меня он выглядит грязным: две операции вместо одной.например, это работает отлично:

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

, кстати, если я игнорирую свойства Name в профиле Automapper, это тоже работает!Даже производная коллекция!

с другой стороны, я думал, что это проблема в разных типах полей (я редко использую postgre), но если я изменяю отображение, например:

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

iПолучена та же ошибка ArgumentException: типы аргументов не совпадают, но идентификатор карты в порядке.

исключение возврата:

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

часть трассировки стека:

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; }
    }

Mapping:

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

Я четко указал отображение этого поля, хотя этоне требуется, конечно

Я пытаюсь проверить план выполнения, например:

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

, но все же, тот же результат.

Спасибо за вашу помощь!

1 Ответ

0 голосов
/ 13 февраля 2019

Если вы не знали, AutoMapper автоматически отображает аргументы с одинаковыми именами.Я подозреваю, что здесь происходит то, что ChatEntity.ChatMembers, ICollection, конфликтует при сопоставлении с ChatMemberDto [] в Dto.ChatMembers.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...