Group by

Матеріал з Вікіпедії — вільної енциклопедії.
Версія від 13:47, 13 травня 2019, створена Рассилон (обговорення | внесок) (правопис, меташаблони)
(різн.) ← Попередня версія | Поточна версія (різн.) | Новіша версія → (різн.)
Перейти до навігації Перейти до пошуку

GROUP BY — синтаксична конструкція мови SQL для агрегації записів, вибраних за допомогою запиту SELECT.

Приклади[ред. | ред. код]

Нехай є таблиця статей, для кожної з яких з-поміж іншого зберігається рік їх написання. Потрібно отримати огляд того, скільки статей було написано кожного року.

SELECT year, count(1)
FROM articles
GROUP BY year;

Результат може бути таким:

year count(1)
2006 7
2007 15
2008 22

Інші можливості[ред. | ред. код]

GROUP BY та агрегатні функції[ред. | ред. код]

Використання GROUP BY дозволяє застосовувати агрегатні функції. Найчастіше використовується для підрахунку кількості записів, відповідних кожному значенню іншого стовпця (у вищенаведеному прикладі року), часто також суми, середнього арифметичного та інших статистичних оцінок вибраних записів.

HAVING[ред. | ред. код]

Див. також: Having (SQL)

У випадках, коли вибірку з GROUP BY необхідно додатково обмежити, а використовувати оператор WHERE не можна, оскільки він не працює з агрегатними функціями, необхідно використовувати спеціальне ключове слово HAVING, яке дозволяє задавати умови над агрегатними функціями.

WITH ROLLUP[ред. | ред. код]

Деякі системи керування базами даних (наприклад, MySQL та MariaDB[1]) підтримують конструкцію WITH ROLLUP, що вживається з оператором GROUP BY. Запит із конструкцією WITH ROLLUP поверне, згідно зі стандартом, рядки зі значенням NULL у тих стовпцях, відповідно до яких дані агрегуються (якщо вказані), а на місці значень агрегатних функцій — результати цих функцій для всіх рядків — наприклад, для кількості (count) це кількість усіх входжень, для суми (sum) — загальна сума і т. д.

Для вищенаведеного прикладу запиту

SELECT year, count(1)
FROM articles
GROUP BY ROLLUP (year);

результат буде схожий на:

year count(1)
2006 7
2007 15
2008 22
NULL 44

Значення NULL в останньому рядку представляє загальний показник за всі роки. Агрегованих стовпців або виразів може бути й більше — тоді результатний набір міститиме значення NULL із загальною сумою у зворотному порядку, крім зазначених в операторі GROUP BY.

Примітки[ред. | ред. код]

Посилання[ред. | ред. код]