В выражении CASE ветки проверяются сверху вниз. Что вернёт CASE WHEN amount IS NULL THEN 'missing' WHEN amount = 0 THEN 'zero' ELSE 'positive' END для строки, где amount равен NULL?
A
'zero'B
'positive'C
'missing'D
NULLПравильный ответ.
CASE выбирает первую подходящую ветку WHEN (где условие TRUE).Разбор
В CASE ветки проверяются по порядку. Для значения NULL первое условие amount IS NULL истинно, поэтому сразу возвращается 'missing', и до проверки amount = 0 дело не доходит. Если бы ветка с IS NULL стояла последней, проверка amount = 0 для NULL дала бы неизвестный результат, и значение попало бы в ELSE. Поэтому наиболее специфичные условия (часто IS NULL) удобно ставить выше по списку.
Проверь себя · 1/3разбор после ответа
Что вернёт выражение
COALESCE(NULL, NULL, 'web', 'app')?Ещё вопросы по теме «Выражения и NULL»
- Нужно выбрать пользователей без электронной почты. Какое условие в `WHERE` корректно найдёт строки, где `email` отсутствует?
- В таблице `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» →