Что вернёт запрос 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 в Telegram

Ещё вопросы по теме «Основы SQL-запросов»