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

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 함수의 => 람다 식에 대한 변수는 무엇이든 될 수 있습니다 (s => s.uid, tv => tv.uid, asdf => asdf.uid). Linq는 Serial 유형의 요소를 선택하는 것으로 자동으로 인식합니다.
Michael

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ᴏʀʏ 2012 년

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

여기서는 메서드 구문으로 전환 한 끝까지 쿼리 구문을 사용했습니다. 그래야 했어? 솔루션에 대한 전체 쿼리 구문 양식이 있습니까?
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.