반응형
LINQ 쿼리에서 GROUP BY를 사용하여 MAX 행을 어떻게 얻습니까?
LINQ에서 다음 SQL 쿼리와 일치하는 방법을 찾고 있습니다.
Select max(uid) as uid, Serial_Number from Table Group BY Serial_Number
정말 이것에 대한 도움을 찾고 있습니다. 위의 쿼리는 Group By
구문으로 인해 각 일련 번호의 최대 uid를 가져옵니다 .
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()
};
}
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) }
메소드 체인 형식 :
db.Serials.GroupBy(i => i.Serial_Number).Select(g => new
{
Serial_Number = g.Key,
uid = g.Max(row => row.uid)
});
LinqPad에서 DamienG의 답변을 확인했습니다. 대신에
g.Group.Max(s => s.uid)
해야한다
g.Max(s => s.uid)
감사합니다!
이 두 필드 만 필요하면 대답은 괜찮지 만 더 복잡한 개체의 경우이 방법이 유용 할 수 있습니다.
from x in db.Serials
group x by x.Serial_Number into g
orderby g.Key
select g.OrderByDescending(z => z.uid)
.FirstOrDefault()
... 이것은 "새로 선택"을 방지합니다
참고 URL : https://stackoverflow.com/questions/157786/how-do-i-get-the-max-row-with-a-group-by-in-linq-query
반응형
'program story' 카테고리의 다른 글
속성의 속성이 null인지 확인하는 C # 우아한 방법 (0) | 2020.09.18 |
---|---|
jquery를 사용하여 라디오에서 이벤트를 클릭하거나 변경하십시오. (0) | 2020.09.18 |
DIV를 하단 또는 기준선에 정렬 (0) | 2020.09.18 |
파이썬에서 사전을 어떻게 병합합니까? (0) | 2020.09.18 |
HTTP POST 요청에 JSON 전달 (0) | 2020.09.18 |