Как получить строку MAX с запросом GROUP BY в LINQ?
Я ищу способ в LINQ, чтобы соответствовать SQL Query.
Select max(uid) as uid, Serial_Number from Table Group BY Serial_Number
Искренне ищем некоторую помощь в этом вопросе. Вышеприведенный запрос получает максимальный uid для каждого серийного номера из-за синтаксиса Group By
.
Ответы
Ответ 1
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()
};
}
Ответ 2
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) }
Ответ 3
Я проверил ответ DamienG в LinqPad.
Вместо
g.Group.Max(s => s.uid)
должен быть
g.Max(s => s.uid)
Спасибо!
Ответ 4
В форме цепочки методов:
db.Serials.GroupBy(i => i.Serial_Number).Select(g => new
{
Serial_Number = g.Key,
uid = g.Max(row => row.uid)
});
Ответ 5
Ответы "ОК", если вам нужны только эти два поля, но для более сложного объекта, возможно, этот подход может быть полезен:
from x in db.Serials
group x by x.Serial_Number into g
orderby g.Key
select g.OrderByDescending(z => z.uid)
.FirstOrDefault()
... это позволит избежать "выбрать новый"