Обходной путь EF Core для DistinctBy вызывает другие ошибкиC#

Место общения программистов C#
Ответить
Anonymous
 Обходной путь EF Core для DistinctBy вызывает другие ошибки

Сообщение Anonymous »

Запрос:

Код: Выделить всё

List productCodes = GetProductCodes();
var products = await _context
.Products
.Where(x => productCodes.Contains(x.ProductCode))
.GroupBy(x => x.ProductCode).Select(x => x.First())    // workaround for `DistinctBy`
.Select(x => new { SupplierId = x.Supplier.Id, WarehouseId = x.Warehouse.Id, x.ProductCode, x.Price })
.ToListAsync();
Результат:

InvalidOperationException: выражение LINQ «ProjectionBindingExpression: 0» не удалось
перевести. Либо перепишите запрос в форме, которую можно перевести, либо явно переключитесь на
вычисление клиента, вставив вызов AsEnumerable, AsAsyncEnumerable,
ToList или ToListAsync.

Я использую обходной путь .GroupBy(x => x.Foo).Select(x => x.First()) вместо DistinctBy (x => x.Foo), который в настоящее время не поддерживается.
Из сообщения об ошибке я предполагаю, что проблема в проекции в .Select(); когда я удаляю запрос, запрос работает.
Я мог бы выполнить проекцию позже, но тогда мне пришлось бы получать большие объемы данных даром.
Есть ли способ исправить/обойти это?


Подробнее здесь: https://stackoverflow.com/questions/786 ... her-errors
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»