Я использую LINQ для IQueryable, возвращаемого из NHibernate, и мне нужно выбрать строку с максимальным значением (значениями) в нескольких полях.
Я упростил бит, который я придерживаюсь. Мне нужно выбрать одну строку из моей таблицы с максимальным значением в одном поле.
var table = new Table { new Row(id: 1, status: 10), new Row(id: 2, status: 20) }
from u in table
group u by 1 into g
where u.Status == g.Max(u => u.Status)
select u
Это неверно, но я не могу найти правильную форму.
Кстати, чего я на самом деле пытаюсь достичь, примерно так:
var clientAddress = this.repository.GetAll()
.GroupBy(a => a)
.SelectMany(
g =>
g.Where(
a =>
a.Reference == clientReference &&
a.Status == ClientStatus.Live &&
a.AddressReference == g.Max(x => x.AddressReference) &&
a.StartDate == g.Max(x => x.StartDate)))
.SingleOrDefault();
Я начал с вышеупомянутой лямбда, но я использовал LINQPad, чтобы попытаться выработать синтаксис для выбора Max().
UPDATE
Удаление GroupBy было ключевым.
var all = this.repository.GetAll();
var address = all
.Where(
a =>
a.Reference == clientReference &&
a.Status == ClientStatus.Live &&
a.StartDate == all.Max(x => x.StartDate) &&
a.AddressReference == all.Max(x => x.AddressReference))
.SingleOrDefault();