Как получить доступ к свойству IQueryable после группы с помощью LINQ?C#

Место общения программистов C#
Ответить
Anonymous
 Как получить доступ к свойству IQueryable после группы с помощью LINQ?

Сообщение Anonymous »

Вот мой запрос на группировку продуктов по категориям, который работает.

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

var products = _db.Products
.Include(p => p.Category).ToList()
.GroupBy(p => new { p.CategoryId })
.Select(g => new
{
CategoryId = g.Key.CategoryId,
Sum = g.Sum(x => x.Price),
Products = g.ToList()
//ProductsTest = g.ToDictionary(x => x.Name, y => y.Price)
});
Как я могу добиться того же, не преобразуя продукты в список после .Include(p => p.Category), потому что для этой группы мне нужна нумерация страниц, сортировка и т. д.?
Когда я пытаюсь запустить это без .ToList(), я получаю следующую ошибку:

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

The LINQ expression 'GroupByShaperExpression:
KeySelector: new { CategoryId = p.CategoryId },
ElementSelector:EntityShaperExpression:
EntityType: Product
ValueBufferExpression:
ProjectionBindingExpression: EmptyProjectionMember
IsNullable: False
.ToList()' could not be translated. Either rewrite the query in a form that can be translated, or switch to client evaluation explicitly by inserting a call to 'AsEnumerable', 'AsAsyncEnumerable', 'ToList', or 'ToListAsync'. See https://go.microsoft.com/fwlink/?linkid=2101038 for more information.
Проблема аналогична остальным методам расширения: FirstOrDefault(), First()...
Может ли разбиение на страницы в этом случае повысить производительность или нет?
И нужно ли мне использовать для этого другую логику или я что-то упускаю? Спасибо :)

Подробнее здесь: https://stackoverflow.com/questions/702 ... using-linq
Ответить

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

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

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

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

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