LINQクエリでGROUP BYを使用してMAX行を取得するにはどうすればよいですか?


94

LINQで次のSQLクエリに一致する方法を探しています。

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

これについて本当に助けを求めています。上記のクエリは、Group By構文のため、各シリアル番号の最大UIDを取得します。

回答:


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 2008年

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 2008年

また、Max関数の=>ラムダ式の変数は何でもかまいません(s => s.uid、tv => tv.uid、asdf => asdf.uid)。Linqは、シリアルタイプの要素を選択するものとして自動的に認識します。
マイケル

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

これらの2つのフィールドのみが必要な場合は答えは大丈夫ですが、より複雑なオブジェクトの場合、このアプローチが役立つ可能性があります。

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

...これは「新規選択」を回避します


私はこれが好きです-他の答えと同じくらい効率的かどうか知っていますか?
noelicus

ここでは、クエリ構文を最後まで使用し、メソッド構文に切り替えました。あなたはしなければなりませんでしたか?ソリューションの完全なクエリ構文フォームはありますか?
Seth

0

これは、LINQラムダ式でGroupByおよびSelectManyを使用して行うことができます

var groupByMax = list.GroupBy(x=>x.item1).SelectMany(y=>y.Where(z=>z.item2 == y.Max(i=>i.item2)));
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.