LINQ GroupBy with Sum

Ray*_*Ray 1 c# linq

我正在尝试使用LINQ查询获取客户最受欢迎的产品(按数量排序最多).运行此SQL查询时,我得到了正确的结果:

SELECT TOP(15) i.ProductId, p.Description, Sum(i.Quantity) As QuantityOrdered
FROM Orders o 
INNER JOIN OrderItems i ON o.Id = i.OrderId
INNER JOIN Products p ON i.ProductId = p.Id 
WHERE o.ClientId = 19
GROUP BY ProductId, Description
ORDER BY QuantityOrdered DESC
Run Code Online (Sandbox Code Playgroud)

它给了我正确的结果:

在此输入图像描述

我正在尝试使用LINQ复制这些结果,这是我到目前为止所拥有的:

var query = _context.Set<OrderItem>()
            .Where(oi => oi.Order.ClientId == input.ClientId)
            .GroupBy(oi => oi.ProductId)
            .Select(group => group.Sum(item => item.Quantity))
            .Take(15);
Run Code Online (Sandbox Code Playgroud)

我在这里得到的是Sums列表,但我不知道如何包含产品ID和描述.其次,我如何包含OrderBy以便最高的总和出现?

Rus*_*Cam 6

您需要投影ProductIdDescription还有Sum()Select投影:

var query = _context.Set<OrderItem>()
    .Where(oi => oi.Order.ClientId == input.ClientId)
    .GroupBy(oi => oi.ProductId)
    .Select(group => 
        new { 
            ProductId = group.Key, 
            Description = group.First().Description, 
            Sum = group.Sum(item => item.Quantity)
            })
    .OrderByDescending(i => i.Sum)
    .Take(15);
Run Code Online (Sandbox Code Playgroud)

组密钥是ProductId我们可以使用它来投影密钥.在Description我们需要从该组中的第一个项目得到的.