АгрегатыНачальный
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';
Связанные термины
Анекдоты по теме
— Что такое ROLLUP? — Групповая агрегация с промежуточными итогами. SELECT year, month, SUM(sales) FROM data GROUP BY ROLLUP(year, month); — Добавляет строки: итого за год и итого за всё. — Как сводная таблица в Excel? — Именно. Только в SQL.
— Зачем нужен DISTINCT в COUNT? — COUNT(DISTINCT user_id) считает уникальных пользователей. — А COUNT(user_id) без DISTINCT? — Считает все посещения, включая повторные. — Это как считать людей на концерте vs количество входов.
COUNT(*) и COUNT(col) поспорили. COUNT(*): — Я считаю всех, даже пустых. COUNT(col): — Я считаю только тех, у кого есть значение. NULL в углу: — Меня никто не считает. COUNT(col): — Именно.