获取最受欢迎的3个热门项目C#Linq EF

时间:2020-03-28 16:58:04

标签: c# entity-framework linq asp.net-core

public class OrderItem
{
    [Key]
    public int ItemId { get; set; }
    public int ProductId { get; set; }
    public virtual Product product { get; set; }
    public int Quantity { get; set; }
}
public class Product
{
    [Key]
    public int ProductId { get; set; }
}

这是我的两个班。我想按每种产品的数量来选择最受欢迎的3种产品。喜欢:

[ProductTable]
1
2
3
4


[OrderItemTable]
1, 1, 20
2, 2, 10
3, 3, 5
4, 4, 100
5, 3, 25

结果应该是:
4、3、1或产品列表。
谢谢。

2 个答案:

答案 0 :(得分:3)

我确信这绝不是最佳选择,但我相信这是您想要的

context.Set<OrderItem>()
.GroupBy(x=>x.ProductId)
.Select(x=>new{ProductId=x.Key, QuantitySum=x.Sum(a=>a.Quantity)})
.OrderByDescending(x=>x.QuantitySum)
.Select(x=>x.ProductId)
.Take(3)
.ToList();

答案 1 :(得分:2)

以下代码已经过测试,可以正常工作,希望对您有帮助

var row = (from x in OrderItem
           group x by new { x.ProductId } into val
           select new
           {
               val.Key.ProductId,
               QuantitySum = val.Sum(s => s.Quantity)
           }).OrderByDescending(i => i.QuantitySum).Take(3);