WedX - журнал о программировании и компьютерных науках

Использование Linq для получения сводок и подсчета

У меня есть база данных SQL Server с таблицей событий, в которой хранится около миллиона событий, каждое из которых имеет дату начала, дату конца, заголовок, рейтинг и другие биты.

Мне нужно отобразить список лет, где каждый год отображает 5 событий с самым высоким рейтингом и общее количество событий в этом году.

Итак, что-то вроде...

Пять главных событий 2009 года (из 199 событий)
 – – А
 – Б
 – В 
 – Г 
 – Е

Пять лучших событий 2010 года (из 469 событий)
 – – F
 – G
 – H
 – I
 – J

.... так далее.

Из-за огромного количества записей я хотел бы избежать запроса Linq, который вытянет все из базы данных, но я не знаю, возможно ли это, и моих знаний Linq недостаточно, чтобы понять, как это будет работать. .

Каков наиболее эффективный метод извлечения этой структуры данных из базы данных?

Заранее большое спасибо - весь день ломал себе голову, пытаясь разобраться.


  • Какой ОРМ вы используете? NHibernate? ЭФ? LINQ для SQL? Что-то еще, у кого есть провайдер LINQ? 02.03.2011

Ответы:


1

Ну, давайте предположим, что вас интересует только дата начала. Вы хотели бы что-то вроде:

var query = from eventInfo in db.Events
            group eventInfo by eventInfo.dateStart.Year into g
            select
            {
                Year = g.Key, // Key for the grouping
                Count = g.Count(), // Events for this year
                Top5 = g.OrderByDescending(e => e.Rating).Take(5)
            };

Честно говоря, я понятия не имею, какой SQL это будет производить, или будет ли он хотя бы смутно эффективен - вы должны узнать сгенерированный SQL, а затем посмотреть в профилировщике SQL, чтобы увидеть план выполнения запроса.

01.03.2011
  • Это гениально - большое спасибо. Пока не уверен насчет производительности, но он определенно делает то, что мне нужно. 02.03.2011

  • 2

    Вам придется использовать ORM, есть несколько возможностей, включая (но не ограничиваясь ими) Linq-To-Sql, Entity Framework, NHibernate (я не уверен здесь в поддержке LINQ) и т. д.

    Все они преобразуют операторы запроса LINQ в SQL-запрос, который будет выполняться в базе данных и будет возвращать только ту информацию, которая вам нужна или запрошена.

    01.03.2011
    Новые материалы

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

    Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
    Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..

    Учебные заметки: создание моего первого пакета Node.js
    Это мои обучающие заметки, когда я научился создавать свой самый первый пакет Node.js, распространяемый через npm. Оглавление Глоссарий I. Новый пакет 1.1 советы по инициализации..

    Забудьте о Matplotlib: улучшите визуализацию данных с помощью умопомрачительных функций Seaborn!
    Примечание. Эта запись в блоге предполагает базовое знакомство с Python и концепциями анализа данных. Привет, энтузиасты данных! Добро пожаловать в мой блог, где я расскажу о невероятных..

    ИИ в аэрокосмической отрасли
    Каждый полет – это шаг вперед к великой мечте. Чтобы это происходило в их собственном темпе, необходима команда астронавтов для погони за космосом и команда технического обслуживания..


    Для любых предложений по сайту: [email protected]