Arhn - архитектура программирования

Сортировать запрос LINQ по дочернему свойству дочерней коллекции?

У меня есть эти объекты:

public class Class
{
     public Guid Id {get;set;}
     public string Name {get;set;}
     public virtual ICollection<Schedule> Schedules{get;set;}
}

public class Schedule
{
     public Guid Id {get;set;}
     public virtual DayOfTheWeekId {get;set;}
     public virtual DayOfTheWeek {get;set;}
     public DateTime StartTime {get;set;}
     public DateTime EndTime {get;set;}
}

Мой текущий запрос выглядит так, но я получаю следующее исключение: По крайней мере один объект должен реализовывать IComparable:

    Repository
.Get(c => c.Schedules.Any(s => s.DayOfTheWeekTypeId == dayOfTheWeekId))
.OrderBy(e => e.Schedules.OrderBy(s => s.StartDateTime)).ToList()

когда я устанавливаю время, я всегда использую один и тот же день, потому что мне нужно показывать занятия в определенные дни недели. Именно здесь в игру вступает объект DayOfTheWeek. Вот как я устанавливаю время:

var schedule = new Schedule{
                           StartDateTime = new DateTime(1999,1,1) + new TimeSpan(9, 15, 0),
                           EndDateTime = new DateTime(1999,1,1) + new TimeSpan(9, 15, 0),
                           DayOfTheWeekTypeId = 1
                           }

Обновление:

Размышляя об этом, я думаю, мне может понадобиться группировка...



Ответы:


1

Вы пытаетесь упорядочить по последовательности. Что это хотя бы значит?

Было бы разумнее упорядочить, скажем, по самому раннему событию в расписании:

.OrderBy(e => e.Schedules.Min(s => s.StartDateTime))

Я не знаю, будет ли это работать, но, по крайней мере, это имеет больше смысла. (Это будет работать в LINQ to Objects. Хотя я понятия не имею о EF.)

14.06.2012
  • это именно то, что мне было нужно, но я только что понял, что буду тянуть все расписания, независимо от дня недели. Мне придется изменить свой запрос, чтобы я вытаскивал только расписания на данный день. 15.06.2012
  • Вы в очередной раз спасли жизнь! 17.03.2018
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..