Как получить строку MAX с запросом GROUP BY in LINQ? - PullRequest
83 голосов
/ 01 октября 2008

Я ищу способ LINQ для соответствия следующему SQL-запросу.

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

Действительно, нужна помощь. Приведенный выше запрос получает максимальный идентификатор каждого серийного номера из-за синтаксиса Group By.

Ответы [ 5 ]

83 голосов
/ 01 октября 2008
        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()
                        };
        }
63 голосов
/ 01 октября 2008
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) }
23 голосов
/ 21 августа 2013

В методах цепочки вида:

db.Serials.GroupBy(i => i.Serial_Number).Select(g => new
    {
        Serial_Number = g.Key,
        uid = g.Max(row => row.uid)
    });
22 голосов
/ 24 июля 2010

Я проверил ответ DamienG в LinqPad. Вместо

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

должно быть

g.Max(s => s.uid)

Спасибо!

8 голосов
/ 24 февраля 2015

Ответы в порядке, если вам нужны только эти два поля, но для более сложного объекта может быть полезен такой подход:

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

... это позволит избежать «выбора нового» * ​​1004 *

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...