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


94

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

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

真的在这方面寻求一些帮助。上面的查询由于Group By语法而获得每个序列号的最大uid 。

Answers:


92
        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()
                        };
        }

1
我想接受这两个答案,但我想我不能,所以我投票给你们两个。谢谢你!
SpoiledTechie.com

68
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) }

我想接受这两个答案,但我想我不能,所以我投票给你们两个。谢谢你!
SpoiledTechie.com'

还请注意,Max函数中=> lambda表达式的变量可以是任何值(s => s.uid,tv => tv.uid,asdf => asdf.uid)。Linq会自动将其识别为选择了Serial类型的元素。
迈克尔

29

以方法链形式:

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

22

我已经在LinqPad中检查了DamienG的答案。代替

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

应该

g.Max(s => s.uid)

谢谢!


10
这可能应该评论DamienG的答案。
Cᴏʀʏ

10

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

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

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


我喜欢-您知道它是否与其他答案一样有效?
noelicus

您一直在这里使用查询语法,直到切换到方法语法为止。一定要吗 您的解决方案是否有完整的查询语法形式?
赛斯

0

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

var groupByMax = list.GroupBy(x=>x.item1).SelectMany(y=>y.Where(z=>z.item2 == y.Max(i=>i.item2)));
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.