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或产品列表。
谢谢。
答案 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);