АгрегатыНачальный
GROUP BY
Группирует строки с одинаковыми значениями для применения агрегатных функций.
Синтаксис
SELECT col, AGG(col2) FROM table GROUP BY col;
Объяснение
GROUP BY схлопывает группы строк в одну. В SELECT можно использовать только колонки из GROUP BY или агрегатные функции.
Порядок: WHERE (фильтр строк) → GROUP BY (группировка) → HAVING (фильтр групп) → SELECT.
Пример
-- Количество заказов и сумма по каждому пользователю SELECT user_id, COUNT(*) AS orders_count, SUM(total) AS total_spent FROM orders GROUP BY user_id ORDER BY total_spent DESC;
Связанные термины
Анекдоты по теме
Почему HAVING обижается на WHERE? — Потому что WHERE фильтрует строки ДО группировки, а HAVING — ПОСЛЕ. WHERE думает, что он главный, а HAVING знает: истина где-то в агрегатах.
— Почему агрегатные функции ненавидят NULL? — Потому что COUNT() их считает, а SUM(колонка) — игнорирует. Двойные стандарты!
— Почему GROUP BY обижается, когда в SELECT есть колонка не из группировки? — Потому что не знает, какое значение выбрать из группы. Ему нужна определённость.