АгрегатыНачальный
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';
Связанные термины
Анекдоты по теме
— Почему новички путают HAVING и WHERE? — Потому что оба фильтруют. Но WHERE — до группировки, а HAVING — после. Как досмотр в аэропорту: сначала смотрят всех (WHERE), потом только прошедших (GROUP BY), а потом ещё раз проверяют группы (HAVING).
Аналитик пишет SUM(revenue) и получает NULL. Он в панике звонит DBA. DBA: проверь, есть ли NULL в колонке revenue. Аналитик: есть несколько. DBA: один NULL заражает всю сумму. Используй SUM(COALESCE(revenue, 0)).
COUNT(*) и COUNT(col) поспорили. COUNT(*): — Я считаю всех, даже пустых. COUNT(col): — Я считаю только тех, у кого есть значение. NULL в углу: — Меня никто не считает. COUNT(col): — Именно.