Як отримати рядок MAX із запитом GROUP BY у запиті LINQ?


94

Я шукаю спосіб у LINQ, щоб відповідати наступному запиту SQL.

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

Дійсно шукаю допомогу щодо цього. Наведений вище запит отримує максимальний ідентифікатор кожного серійного номера через Group Byсинтаксис.

Відповіді:


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

69
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.
Майкл

30

У методах ланцюгової форми:

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

22

Я перевірив відповідь DamienG у LinqPad. Замість

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

має бути

g.Max(s => s.uid)

Дякую!


10
Це, мабуть, має прокоментувати відповідь DamienG.
Cᴏʀʏ 07.03.12

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

Це можна зробити за допомогою GroupBy та SelectMany у виразі LINQ lamda

var groupByMax = list.GroupBy(x=>x.item1).SelectMany(y=>y.Where(z=>z.item2 == y.Max(i=>i.item2)));
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.