Аналитик пишет: SELECT clicks / NULLIF(views, 0) AS ctr FROM campaigns. Зачем здесь используется NULLIF(views, 0)?
AВыражение
NULLIF заменяет NULL в views на 0, чтобы деление всегда возвращало числоBВыражение
NULLIF вернёт NULL вместо views, если views равен 0, и деление даст NULLCВыражение
NULLIF вернёт 0 вместо views, если views равен NULL, для безопасного деленияDВыражение
NULLIF вернёт ошибку, если views равен 0, чтобы предотвратить некорректный расчётПравильный ответ.
NULLIF(a, b) возвращает NULL, если a = b, иначе возвращает a. Это защищает от деления на ноль.Разбор
NULLIF(views, 0) вернёт NULL, если views равен 0, и само значение views в остальных случаях. Деление на NULL в SQL возвращает NULL (а не ошибку), поэтому строки с нулём просмотров получат NULL в столбце ctr вместо ошибки деления на ноль. Это стандартный защитный паттерн при расчёте метрик.
Проверь себя · 1/3разбор после ответа
В таблице
payments нужно выбрать платежи из России (country = 'RU') со статусом либо 'failed', либо 'chargeback'. Какой WHERE корректный?Ещё вопросы по теме «Основы 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-запросов» →