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