7 / 7 / 1
Регистрация: 09.10.2014
Сообщений: 30

Сортировка и группировка

07.04.2016, 12:57. Показов 5732. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Код привожу с сокращениями. Делаю запрос:
MySQL
1
2
3
4
5
SELECT operitems.ORD ord, job.DATE job_date, job.ID job_id
FROM okb_db_operitems operitems
LEFT JOIN okb_db_job job ON operitems.ID = job.ID_operitems 
WHERE operitems.ID_zakmod=19582 
ORDER BY ord, job_date DESC
MySQL выдаёт что-то вроде:
Code
1
2
3
4
5
6
7
8
9
10
11
ord   job_date  job_id
5     20160324  109869
5     20151209  109530
10    20160324  109531
10    20151223  109529
15    NULL      NULL
20    20160301  105075
20    20160229  105515
25    20160301  105076
25    20160229  105516
30    NULL      NULL
Необходимо сгруппировать вывод запроса по полю ord с одновременной сортировкой по полю job_date. Делаю так:
MySQL
1
2
3
4
5
6
7
8
SELECT * FROM
(
SELECT operitems.ORD, job.DATE, job.ID
FROM okb_db_operitems operitems
LEFT JOIN okb_db_job job ON operitems.ID = job.ID_operitems 
WHERE operitems.ID_zakmod=19582 
ORDER BY ord, job_date DESC 
) tbl GROUP BY ord
Но на выходе получаю :
Code
1
2
3
4
5
6
7
ord   job_date  job_id
5     20151209  87492 
10    20151223  90464
15    NULL      NULL
20    20160301  105075
25    20160301  105076
30    NULL      NULL
Т.е. вне зависимости от типа сортировки по полю job ( ASC/DESC ), при группировке по полю ord, в результирующий вывод запроса вставляется не самое большое значение, а какое-то предыдущее. Можно, разумеется, это разрулить последующей обработкой в PHP, но неужели нет нормального решения средствами SQL? Поискал в сети, вопрос не новый, но работающего решения я не нашёл. Выбрать по MAX(job) - не выход, в реальной базе ещё много нужных полей и нужна строка целиком. Работаю с MySQL.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.04.2016, 12:57
Ответы с готовыми решениями:

Сортировка и группировка
Есть гипотетическая задача: Несколько пользователей отвечают на тест из 9-ти вопросов. (Предположительно у каждого ответа есть свой...

Сортировка(группировка)
Нужно в запросе сделать группировку(сортировку) по числу в месяце с 01 по 15 число при этом месяц и год могут быть любыми, с SQL не...

Сортировка и группировка коллекции
Можно ли в public int CompareTo(Transport obj) { if (this.Consumption > obj.Consumption) ...

6
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
07.04.2016, 13:05
Цитата Сообщение от shindax Посмотреть сообщение
неужели нет нормального решения средствами SQL
ORDER BY всегда д.б. во внешнем запросе, тогда он выполняется последним. Иначе не имеет смысла
0
Native x86
Эксперт Hardware
 Аватар для quwy
6857 / 3790 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
07.04.2016, 13:10
Большинство СУБД такой запрос вообще не стало бы выполнять, потому как если есть группировка, то все поля, которые не участвуют в группировке, должны быть обработаны агрегирующими функциями. То есть, если есть таблица (или подвыборка) из полей ORD, DATE, ID и при этом выполняется группировка по ORD, то поля DATE и ID не могут быть выведены просто так. Почему? А по тому, что объединяя несколько записей с одинаковым ORD, но разными DATE и ID, сервер не имеет четких критериев выбора той записи, из которой нужно вынуть эти значения, потому как все записи равноправны перед оператором объединения (и их порядок не имеет никакого значения). Единственным четким критерием является агрегация значений из всех объединенных записей по какому-либо четкому закону. Это может быть MAX(DATE) и MIN(ID), или MIN(DATE) и SUM(ID) и т.п. То, что MySQL по старой PHP-шной традиции "лучше сделать что попало вместо того, чтобы бросить ошибку" дает вам выполнить такой запрос, еще не значит что его критерий выбора значения в неопределенной ситуации совпадет с вашими пожеланиями.
0
7 / 7 / 1
Регистрация: 09.10.2014
Сообщений: 30
07.04.2016, 13:17  [ТС]
На значения в столбце job_id в моём сообщении не обращайте внимания, туда мусор попал. Та что, программно всё-же пережёвывать выдачу MySQL? Пробовал я MAX, но подставляется только само число, но не остальные данные из строки. Я полагал, что MySQL возьмёт первую строку после всех сортировок и отбросит те, что совпадают с полем указанным в GROUP. Подскажите тогда, как такую простую задачу выполнить штатными средствами SQL, если можно, то на примере.
0
Zero day
 Аватар для Meridian21
267 / 231 / 78
Регистрация: 16.12.2015
Сообщений: 943
Записей в блоге: 4
07.04.2016, 14:09
shindax, вариант дописать в конце запроса order by по полю job_date asc/desc не вариант? Операция сортировки выполняется в конце всех работ с результирующим массивом, поэтому из середины запроса надо order by убрать. В общем-то Grossmeister, уже ответил на вопрос.

SQL
1
2
3
4
5
6
SELECT operitems.ORD, job.DATE
FROM okb_db_operitems.operitems
LEFT JOIN okb_db_job job ON operitems.ID = job.ID_operitems 
WHERE operitems.ID_zakmod=19582 
GROUP BY ord 
ORDER BY job_date
0
411 / 365 / 142
Регистрация: 09.04.2011
Сообщений: 1,051
08.04.2016, 00:03
Лучший ответ Сообщение было отмечено shindax как решение

Решение

Цитата Сообщение от shindax Посмотреть сообщение
Подскажите тогда, как такую простую задачу выполнить штатными средствами SQL, если можно, то на примере.
посмотрите эту статью, там приведено 5 способов решения с помощью sql

Цитата Сообщение от Meridian21 Посмотреть сообщение
вариант дописать в конце запроса order by по полю job_date asc/desc не вариант?
нет, так как order by применяется уже после group by
а задача - как при группировке оставить нужную строку
1
7 / 7 / 1
Регистрация: 09.10.2014
Сообщений: 30
08.04.2016, 05:29  [ТС]
Цитата Сообщение от retvizan Посмотреть сообщение
...нет, так как order by применяется уже после group by
а задача - как при группировке оставить нужную строку
Именно так и происходит. Всем спасибо за участие, почитаю информацию по ссылкам, Пока решил чисто программно, если получится посредством чистого SQL, выложу здесь.

Добавлено через 1 час 54 минуты
Цитата Сообщение от retvizan Посмотреть сообщение
посмотрите эту статью, там приведено 5 способов решения с помощью sql...
Спасибо, классная статья. Лучшее, из того, что я находил в сети по сути проблемы, взял на сайт заметку.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.04.2016, 05:29
Помогаю со студенческими работами здесь

Сортировка и группировка е-майлов
Народ помогите, пожалуйста!!! Всю жизнь работал с Оутлуком, он не без косяков конечно, но интерфейс юзабельней чем в Лотусе. ...

Сортировка и группировка данных в DataGridView
Много времени потратил на поиски оптимального решения по сортировки и группировки данных в DataGridView. Надеюсь это кому то поможет. ...

Сортировка (группировка) файлов по типу
Здравствуйте ребята! у меня такая задача надо сортировать (группировать) файлы по их типу т.е. документы word: *.doc, и т.д.. ...

Access подстановка, группировка, сортировка
Помогите сделать. Пропустил тему. Не могу сделать лабораторку. Ход выполнения работы 1.Схема данных Описать какие связи...

Сортировка и группировка данных в Silverlight3
Кто-нибудь может объяснить почему представления не работают в Silverlight3? Например имеется некий класс SampleCollection который...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru