LINQ to SQL:orderby a sum操作
我有一个表格,我需要根据GROUPBY子句对结果集按数字列求和排序 例如,该表包含销售人员ID、订单号和订单值。我想要一份按累计订单价值排列的前十名销售人员名单 SQL和LINQ新手,如有任何建议,将不胜感激 类似这样:LINQ to SQL:orderby a sum操作,linq,sum,operations,Linq,Sum,Operations,我有一个表格,我需要根据GROUPBY子句对结果集按数字列求和排序 例如,该表包含销售人员ID、订单号和订单值。我想要一份按累计订单价值排列的前十名销售人员名单 SQL和LINQ新手,如有任何建议,将不胜感激 类似这样: var results = context.Sales.GroupBy(s => s.SalesPersonID) .Select(g => new {
var results = context.Sales.GroupBy(s => s.SalesPersonID)
.Select(g => new {
SalesPersonID = g.Key,
Sales = g.Sum(s => s.OrderValue)
})
.OrderByDescending(r => r.Sales)
.Take(10);
var orders = new[]
{
new Order { SalesPersonId = 1, OrderNumber = 1, OrderValue = 1 },
new Order { SalesPersonId = 1, OrderNumber = 2, OrderValue = 2 },
new Order { SalesPersonId = 2, OrderNumber = 2, OrderValue = 2 },
};
var topSalesMen = orders
.GroupBy(arg => arg.SalesPersonId)
.Select(arg => new { SalesPersonId = arg.Key, TotalOrderValue = arg.Sum(x => x.OrderValue) })
.OrderByDescending(arg => arg.TotalOrderValue)
.Take(10)
.ToList();