Получите максимум + мин в одной строке с linq
Как я могу изменить этот метод, чтобы он также возвращал Max(t.StartTime) и Min(t.StartTime), используя его только в одной строке, как показано ниже?
public IQueryable<Timetable> GetTimetables()
{
return from t in _entities.Timetables
select t;
}
/ M
2 ответа
Решение
С головы до головы (читай: не проверено) и предполагая, что StartTime не обнуляется:
public class TimetableWithMaxMin
{
public Timetable Timetable { get; set; }
public DateTime Max { get; set; }
public DateTime Min { get; set; }
}
public IQueryable<TimetableWithMaxMin> GetTimetables()
{
return from t in _entities.Timetables
select new TimetableWithMaxMin
{
Timetable = t,
Max = _entities.Timetables.Max(t => t.StartTime),
Min = _entities.Timetables.Min(t => t.StartTime)
};
}
Это значительно усложняется, когда StartTime обнуляется.
Я не знаю, применимо ли это к платформе Entity, но с linq это примерно так
public IQueryable<Timetable> GetTimetables()
{
return from t in _entities.Timetables
select new {maxt = Max(t.StartTime), mint = Min(t.StartTime)};
}