Что вернёт выражение CASE WHEN is_active = 1 THEN 'active' END для строки, где is_active = 0?
A
'active'B
NULLC
0D
'inactive'Правильный ответ. Если в
CASE нет ELSE, то при отсутствии подходящего WHEN результат — NULL.Разбор
В выражении CASE WHEN is_active = 1 THEN 'active' END есть только одна ветка и нет ELSE. Для строки с is_active = 0 условие is_active = 1 ложно, поэтому ни одна ветка не сработает и CASE вернёт NULL. Чтобы получить явное значение, добавляют ELSE 'inactive'.
Проверь себя · 1/3разбор после ответа
Вы хотите заменить
NULL в referrer на 'direct'. Что проще и эквивалентно по смыслу?Ещё вопросы по теме «Выражения и NULL»
- Нужно выбрать пользователей без email. Какое условие в `WHERE` корректно найдёт строки, где `email` отсутствует (равен `NULL`)?
- В таблице `orders` поле `promo_code` может быть `NULL`. Что произойдёт со строкой, где `promo_code` = `NULL`, при фильтре `WHERE promo_code <> 'NONE'`?
- В таблице `sessions` 5 строк. Значения `utm_source`: `'google'`, `NULL`, `'email'`, `NULL`, `NULL`. Чему равны `COUNT(*)` и `COUNT(utm_source)`?
- В таблице `payments` три строки со значениями `amount`: `NULL`, `NULL`, `NULL`. Что вернут запросы `SELECT SUM(amount)` и `SELECT SUM(COALESCE(amount, 0))`?
- Что вернёт выражение `COALESCE(NULL, NULL, 'web', 'app')`?
- Все вопросы по «Выражения и NULL» →