当前位置:  开发笔记 > 数据库 > 正文

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

如何解决《如何在LINQ查询中使用GROUPBY获取MAX行?》经验,为你挑选了5个好方法。

我在LINQ中寻找一种方法来匹配后面的SQL查询.

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

真的在寻找这方面的一些帮助.由于Group By语法,上面的查询获取每个序列号的最大值.



1> tvanfosson..:
        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()
                        };
        }



2> DamienG..:
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) }



3> Lu55..:

在方法链形式:

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



4> denis_n..:

我已经检查过DamienG在LinqPad中的答案.代替

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

应该

g.Max(s => s.uid)

谢谢!


这应该是对DamienG答案的评论.

5> Javier..:

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

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

...这将避免"选择新"

推荐阅读
可爱的天使keven_464
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有