У пользователя price = 100 и discount = NULL. Что вернёт выражение SELECT price + discount FROM products для этой строки?

AРезультат будет NULL, потому что любая арифметическая операция с NULL возвращает NULL
BРезультат будет 100, потому что NULL в сложении автоматически заменяется на 0
CЗапрос вызовет ошибку, потому что нельзя складывать число и NULL в SQL
DРезультат будет 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 в Telegram

Ещё вопросы по теме «Основы SQL-запросов»