У пользователя price = 100 и discount = NULL. Что вернёт выражение SELECT price + discount FROM products для этой строки?
AРезультат будет
NULL, потому что любая арифметическая операция с NULL возвращает NULLBРезультат будет
100, потому что NULL в сложении автоматически заменяется на 0CЗапрос вызовет ошибку, потому что нельзя складывать число и
NULL в SQLDРезультат будет
0, потому что NULL интерпретируется как нулевое значениеПравильный ответ. Любая арифметическая операция с
NULL в SQL даёт NULL, а не числовой результат.Разбор
В SQL NULL означает «неизвестное значение», а не ноль. Поэтому 100 + NULL даёт NULL: результат сложения известного числа с неизвестным тоже неизвестен. Чтобы заменить NULL на конкретное значение, используют COALESCE: price + COALESCE(discount, 0) вернёт 100.
Проверь себя · 1/3разбор после ответа
Вы строите выдачу «последние заказы» и используете
LIMIT 50. Поле created_at не уникально (много заказов в одну секунду). Какой ORDER BY лучше, чтобы порядок был детерминированным?Ещё вопросы по теме «Основы 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-запросов» →