В таблице users столбец is_test может быть 0, 1 или NULL. Нужно исключить тестовых пользователей (где is_test = 1), но оставить остальных, включая NULL. Какой фильтр корректен?
A
WHERE is_test <> 1B
WHERE is_test = 0C
WHERE is_test <> 1 OR is_test IS NULLD
WHERE is_test != NULLПравильный ответ. Условие
<> исключает строки с NULL, если не добавить явную проверку.Разбор
WHERE is_test <> 1 не пропустит строки с is_test = NULL, потому что сравнение даст UNKNOWN. Если по смыслу NULL означает «неизвестно/не отмечен» и таких пользователей нужно оставить, добавляют OR is_test IS NULL. Вариант WHERE is_test = 0 тоже исключит NULL, что меняет смысл выборки.
Проверь себя · 1/3разбор после ответа
Нужно посчитать выручку по заказу как
price * quantity, где quantity может быть NULL (не заполнили). По бизнес-правилу NULL нужно считать как 1. Какое выражение корректнее?Ещё вопросы по теме «Выражения и 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» →