Запрос: SELECT country, COUNT(DISTINCT user_id) FROM events GROUP BY country. Таблица содержит повторяющиеся строки. Что посчитает функция?
AРазницы нет:
COUNT(DISTINCT user_id) и COUNT(user_id) дают одинаковый результат при наличии GROUP BYB
COUNT(DISTINCT user_id) не работает внутри GROUP BY — нужен отдельный подзапросCВ каждой группе считаются уникальные
user_id внутри этой группы, а не по всей таблицеD
COUNT(DISTINCT user_id) с GROUP BY считает уникальных пользователей по всей таблице, игнорируя разбивкуПравильный ответ.
COUNT(DISTINCT col) внутри GROUP BY считает уникальные значения столбца в пределах каждой группы отдельно, а не по всей таблице.Разбор
COUNT(DISTINCT expr) всегда работает в границах текущей группы. При GROUP BY country уникальные user_id считаются отдельно для каждой страны. Если пользователь совершил события в двух странах, он будет засчитан в обеих группах — это ожидаемое поведение. Никакого ограничения на сочетание DISTINCT и GROUP BY нет.
Проверь себя · 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» →