Відмінності між версіями «Group by»

Матеріал з Вікіпедії — вільної енциклопедії.
Перейти до навігації Перейти до пошуку
[неперевірена версія][неперевірена версія]
(Створено шляхом перекладу сторінки «GROUP BY»)
 
(вікіфікація, оформлення, правопис, шаблон, зовнішні посилання)
Рядок 1: Рядок 1:
  +
{{без джерел|дата=січень 2017}}
'''<code>GROUP BY</code>''' — [[Синтаксис|синтаксична конструкція]] мови [[SQL]] для [[Агрегація|агрегації]] записів, вибраних за допомогою [[Запити мови SQL|запиту]] [[Select (SQL)|SELECT]].
+
'''GROUP BY'''&nbsp;— [[Синтаксис|синтаксична конструкція]] мови [[SQL]] для [[Агрегація|агрегації]] записів, вибраних за допомогою {{не перекладено|Запити мови SQL|запиту|cz|Příkazy jazyka SQL}} [[Select (SQL)|SELECT]].
; Приклад використання<br>
 
  +
Нехай є таблиця статей, для кожної з яких з-поміж іншого зберігається рік їх написання. Потрібно отримати огляд того, скільки статей було написано кожного року.<source lang="sql">
 
  +
== Приклади ==
SELECT rok,Count(*) FROM clanky GROUP BY rok;
 
 
Нехай є таблиця статей, для кожної з яких з-поміж іншого зберігається рік їх написання. Потрібно отримати огляд того, скільки статей було написано кожного року.
</source>Результат може бути таким:
 
  +
<source lang="sql">
+------+----------+
 
| year | count(*) |
+
SELECT year, count(*)
  +
FROM articles
+------+----------+
 
  +
GROUP BY year;
| 2006 | 7 |
 
  +
</source>
| 2007 | 15 |
 
 
Результат може бути таким:
| 2008 | 22 |
 
  +
{|class="wikitable"
+------+----------+
 
  +
|-
 
! year !! count(*)
  +
|-
 
| 2006 || 7
  +
|-
 
| 2007 || 15
  +
|-
 
| 2008 || 22
  +
|}
   
 
== Інші можливості ==
 
== Інші можливості ==
   
=== <code>GROUP BY</code> та агрегатні функції ===
+
=== GROUP BY та агрегатні функції ===
  +
{{Див. також|Агрегатна функція}}
{{Див. також|Агрегатна функція<br>}}Використання <code>GROUP BY</code> дозволяє оголошувати агрегатні функції. Найчастіше використовується для підрахунку кількості записів, відповідних кожному значенню іншого стовпця (у вищенаведеному прикладі року), часто також суми, [[Середнє арифметичне|середнього арифметичного]] та інших [[Статистика|статистичних]] оцінок вибраних записів.
+
Використання <code>GROUP BY</code> дозволяє застосовувати агрегатні функції. Найчастіше використовується для підрахунку кількості записів, відповідних кожному значенню іншого стовпця (у вищенаведеному прикладі року), часто також суми, [[Середнє арифметичне|середнього арифметичного]] та інших [[Статистична оцінка|статистичних оцінок]] вибраних записів.
  +
 
=== HAVING ===
  +
{{Див. також|Having (SQL)}}
 
У випадках, коли вибірку з <code>GROUP BY</code> необхідно додатково обмежити, а використовувати оператор [[Where (SQL)|WHERE]] не можна, оскільки він не працює з агрегатними функціями, необхідно використовувати спеціальне ключове слово <code>HAVING</code>, яке дозволяє задавати умови над агрегатними функціями.
  +
 
=== WITH ROLLUP ===
 
Деякі системи керування базами даних (наприклад, [[MySQL]]) підтримують конструкцію <code>WITH ROLLUP</code>, що вживається з оператором <code>GROUP BY</code>. Запит із конструкцією <code>WITH ROLLUP</code> поверне, згідно зі стандартом, рядки зі значенням [[Null (SQL)|NULL]] у тих стовпцях, відповідно до яких дані агрегуються (якщо вказані), а на місці значень агрегатних функцій&nbsp;— результати цих функцій для всіх рядків&nbsp;— наприклад, для кількості (<code>count</code>) це кількість усіх входжень, для суми (<code>sum</code>)&nbsp;— загальна сума і&nbsp;т.&nbsp;д.
   
 
Для вищенаведеного прикладу запиту
=== <code>HAVING</code> ===
 
  +
<source lang="sql">
{{Див. також|Having (SQL)<br>}}У випадках, коли вибірку з <code>GROUP BY</code> необхідно додатково обмежити, а використовувати оператор <code>WHERE</code> не можна, оскільки він не працює з агрегатними функціями, необхідно використовувати спеціальне ключове слово <code>HAVING</code>, яке дозволяє задавати умови над агрегатними функціями.
 
  +
SELECT year, count(*)
  +
FROM articles
  +
GROUP BY year;
  +
</source>
 
результат буде схожий на:
  +
{|class="wikitable"
  +
|-
  +
! year !! count(*)
  +
|-
 
| 2006 || 7
  +
|-
 
| 2007 || 15
  +
|-
 
| 2008 || 22
  +
|-
 
| NULL || 44
  +
|}
   
 
Значення [[Null (SQL)|NULL]] в останньому рядку представляє загальний показник за всі роки. Агрегованих стовпців або виразів може бути й більше&nbsp;— тоді результатний набір міститиме значення NULL із загальною сумою у зворотньому порядку, крім зазначених в операторі <code>GROUP BY</code>.
=== <code>WITH ROLLUP</code> ===
 
Деякі системи керування базами даних (наприклад, [[MySQL]]) підтримують конструкцію <code>WITH ROLLUP</code>, що вживається з оператором <code>GROUP BY</code>. Запит із конструкцією <code>WITH ROLLUP</code> поверне, згідно зі стандартом, рядки зі значенням [[NULL]] у тих стовпцях, відповідно до яких дані агрегуються (якщо вказані), а на місці значень агрегатних функцій — результати цих функцій для всіх рядків — наприклад, для кількості (<tt>count</tt>) це кількість усіх входжень, для суми (<tt>sum</tt>) — загальна сума і т.д.
 
   
  +
== Посилання ==
Для вищенаведеного прикладу запиту<source lang="sql">
 
  +
* {{Cite web|url=http://www.w3schools.com/sql/sql_groupby.asp|назва=SQL GROUP BY Statement|веб-сайт={{не перекладено|W3Schools}}|мовою=англійською|мертвий-url=no|дата-доступу=5 січня 2017}}
SELECT rok,Count(*) FROM clanky GROUP BY rok WITH ROLLUP;
 
  +
* {{Cite web|url=http://dev.mysql.com/doc/refman/5.7/en/group-by-modifiers.html|назва=GROUP BY MOdifiers|веб-сайт=[[MySQL]]|мовою=англійською|мертвий-url=no|дата-доступу=5 січня 2017}}
</source>результат буде схожий на:
 
+------+----------+
 
| year | count(*) |
 
+------+----------+
 
| 2006 | 7 |
 
| 2007 | 15 |
 
| 2008 | 22 |
 
| NULL | 44 |
 
+------+----------+
 
Значення [[NULL]] в останньому рядку представляє загальний показник за всі роки. Агрегованих стовпців або виразів може бути й більше — тоді результатний набір міститиме значення NULL із загальною сумою у зворотньому порядку, крім зазначених в операторі <code>GROUP BY</code>.
 
   
  +
{{Database-stub}}
  +
{{SQL}}
 
[[Категорія:SQL]]
 
[[Категорія:SQL]]

Версія за 11:07, 5 січня 2017

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

Приклади

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

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

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

year count(*)
2006 7
2007 15
2008 22

Інші можливості

GROUP BY та агрегатні функції

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

HAVING

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

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

WITH ROLLUP

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

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

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

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

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

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

Посилання