如何在 LINQ 查询中使用 GROUP BY 获取 MAX 行?

问题描述 投票:0回答:7

我正在 LINQ 中寻找一种方法来匹配以下 SQL 查询。

Select max(uid) as uid, Serial_Number from Table Group BY Serial_Number

确实在这方面寻求一些帮助。 由于

Group By
语法,上述查询获取每个序列号的最大 uid。

.net linq linq-to-sql
7个回答
102
投票
using (DataContext dc = new DataContext())
{
    var q = from t in dc.TableTests
            group t by t.SerialNumber
                into g
                select new
                {
                    SerialNumber = g.Key,
                    uid = (from t2 in g select t2.uid).Max()
                };
}

74
投票
var q = from s in db.Serials
        group s by s.Serial_Number into g
        select new {Serial_Number = g.Key, MaxUid = g.Max(s => s.uid) }

44
投票

以方法链形式:

db.Serials.GroupBy(i => i.Serial_Number).Select(g => new
    {
        Serial_Number = g.Key,
        uid = g.Max(row => row.uid)
    });

24
投票

我已经在 LinqPad 中检查了 DamienG 的答案。 而不是

g.Group.Max(s => s.uid)

应该是

g.Max(s => s.uid)

谢谢!


14
投票

如果您只需要这两个字段,答案就可以,但对于更复杂的对象,也许这种方法可能有用:

from x in db.Serials 
group x by x.Serial_Number into g 
orderby g.Key 
select g.OrderByDescending(z => z.uid)
.FirstOrDefault()

...这将避免“选择新的”


7
投票

这可以使用 LINQ lamda 表达式中的 GroupBy 和 SelectMany 来完成

var groupByMax = list.GroupBy(x=>x.item1).SelectMany(y=>y.Where(z=>z.item2 == y.Max(i=>i.item2)));

0
投票

基于上述内容,我想将每组中的最佳结果放入与原始列表相同类型的列表中:

    var bests = from x in origRecords
            group x by x.EventDescriptionGenderView into g
            orderby g.Key
            select g.OrderByDescending(z => z.AgeGrade)
            .FirstOrDefault();

    List<MasterRecordResultClaim> records = new 
                  List<MasterRecordResultClaim>();
    foreach (var bestresult in bests)
    {
        records.Add(bestresult);
    }

EventDescriptionGenderView 是将多个字段合并成一个字符串。这会为每个事件选择最佳的 AgeGrade。

© www.soinside.com 2019 - 2024. All rights reserved.