В PostgreSQL нужно посчитать сумму продаж только по активным клиентам, не исключая остальных клиентов из итоговой выборки. Какой синтаксис использовать?
AНаписать условие
WHERE status = 'active' перед GROUP BY, чтобы убрать лишние строкиBДобавить
FILTER (WHERE status = 'active') после агрегатной функции в SELECTCИспользовать
HAVING status = 'active' после GROUP BY для фильтрации группDПоместить условие в
ON при JOIN с вспомогательной таблицей статусовПравильный ответ.
FILTER (WHERE ...) применяется к конкретной агрегатной функции и не влияет на остальные агрегаты в том же SELECT, поэтому остальные клиенты остаются в выборке.Разбор
Синтаксис aggregate_func(...) FILTER (WHERE condition) — стандарт SQL:2003, реализованный в PostgreSQL. Он позволяет фильтровать строки для одного агрегата независимо от других: SUM(amount) FILTER (WHERE status='active') суммирует только активных, тогда как COUNT(*) той же группы посчитает всех. Это чище, чем SUM(CASE WHEN status='active' THEN amount END).
Проверь себя · 1/3разбор после ответа
Что вернёт запрос
SELECT AVG(salary) FROM employees;?Ещё вопросы по теме «Агрегация, GROUP BY и HAVING»
- Что делает оператор `DISTINCT`?
- Что делает `HAVING`?
- Есть таблица `orders(user_id, amount)`. Какой запрос посчитает сумму всех заказов по каждому пользователю?
- Нужно посчитать сумму оплаченных заказов по каждому пользователю. В таблице `orders` есть поля `user_id`, `amount`, `status`. Какой запрос корректен и наиболее эффективен?
- В таблице `users` есть колонка `middle_name`, в которой часто хранится `NULL`. Что вернёт выражение `COUNT(middle_name)`?
- Все вопросы по «Агрегация, GROUP BY и HAVING» →