АгрегатыНачальный
SUM / AVG / MIN / MAX
Агрегатные функции для вычисления суммы, среднего, минимума и максимума числовых значений.
Синтаксис
SUM(col) | AVG(col) | MIN(col) | MAX(col)
Объяснение
Все эти функции игнорируют NULL. Если все значения NULL — возвращают NULL (кроме COUNT).
AVG(col) = SUM(col) / COUNT(col). Оба игнорируют NULL, поэтому AVG может ввести в заблуждение — нули и NULL считаются по-разному.
Пример
SELECT SUM(total) AS revenue, AVG(total) AS avg_order, MIN(total) AS min_order, MAX(total) AS max_order FROM orders WHERE status = 'paid';
Связанные термины
Анекдоты по теме
— STRING_AGG — это что? — Агрегирует строки через разделитель. SELECT user_id, STRING_AGG(tag, ', ') FROM user_tags GROUP BY user_id; — Превращает много строк в одну? — Да. Обратное нормализации. — А ARRAY_AGG? — То же самое, но возвращает массив вместо строки.
— Почему новички путают HAVING и WHERE? — Потому что оба фильтруют. Но WHERE — до группировки, а HAVING — после. Как досмотр в аэропорту: сначала смотрят всех (WHERE), потом только прошедших (GROUP BY), а потом ещё раз проверяют группы (HAVING).
— Почему агрегатные функции ненавидят NULL? — Потому что COUNT() их считает, а SUM(колонка) — игнорирует. Двойные стандарты!