Что вернёт запрос SELECT COUNT(DISTINCT user_id) FROM orders, если у некоторых пользователей несколько заказов?
AЗапрос вернёт общее количество строк в таблице
orders без какой-либо дедупликацииBЗапрос вернёт количество строк, где
user_id не равен NULL, включая повторяющиеся значенияCЗапрос вернёт количество уникальных значений
user_id, пропуская NULL и дубликатыDЗапрос вернёт ошибку, потому что
DISTINCT нельзя использовать внутри агрегатной функцииПравильный ответ.
COUNT(DISTINCT столбец) считает количество уникальных непустых значений в указанном столбце.Разбор
COUNT(DISTINCT user_id) сначала убирает дубликаты и NULL из значений user_id, а затем считает оставшиеся уникальные значения. Если в таблице 1000 заказов от 300 разных пользователей — результат будет 300. Это стандартный способ подсчёта уникальных сущностей: уникальных покупателей, уникальных товаров и т.д.
Проверь себя · 1/3разбор после ответа
Аналитик пишет:
SELECT clicks / NULLIF(views, 0) AS ctr FROM campaigns. Зачем здесь используется NULLIF(views, 0)?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям вам нужны только `user_id` и `signup_at` из таблицы `users`. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в запросе нет `ORDER BY`?
- Все вопросы по «Основы SQL-запросов» →