Вы хотите вывести только те категории товаров, где суммарные продажи больше 10000. Таблица sales с колонками category, amount. Какой запрос корректен?
A
SELECT category, SUM(amount) FROM sales WHERE SUM(amount) > 10000 GROUP BY category;B
SELECT category, SUM(amount) FROM sales GROUP BY category HAVING SUM(amount) > 10000;C
SELECT category, amount FROM sales GROUP BY category HAVING amount > 10000;D
SELECT category, SUM(amount) FROM sales HAVING SUM(amount) > 10000;Правильный ответ. Условия по агрегатам (
SUM, COUNT и др.) задаются в HAVING после GROUP BY.Разбор
Клаузу WHERE нельзя использовать с агрегатными функциями, она фильтрует отдельные строки до группировки. Для фильтрации групп по сумме продаж нужен HAVING: SELECT category, SUM(amount) FROM sales GROUP BY category HAVING SUM(amount) > 10000;.
Проверь себя · 1/3разбор после ответа
В таблице
users есть колонка middle_name, в которой часто хранится NULL. Что вернёт выражение COUNT(middle_name)?Ещё вопросы по теме «Агрегация, GROUP BY и HAVING»
- Что делает оператор `DISTINCT`?
- Что делает `HAVING`?
- Есть таблица `orders(user_id, amount)`. Какой запрос посчитает сумму всех заказов по каждому пользователю?
- Нужно посчитать сумму оплаченных заказов по каждому пользователю. В таблице `orders` есть поля `user_id`, `amount`, `status`. Какой запрос корректен и наиболее эффективен?
- В таблице `users` есть колонка `middle_name`, в которой часто хранится `NULL`. Что вернёт выражение `COUNT(middle_name)`?
- Все вопросы по «Агрегация, GROUP BY и HAVING» →