В таблице заказов поле cancelled_at заполняется только для отменённых заказов, а для активных оно равно NULL. Какой фильтр выберет именно активные (не отменённые) заказы?
AФильтр
WHERE cancelled_at IS NULL оставит активные строки без даты отменыBФильтр
WHERE cancelled_at = NULL отберёт строки, где значение поля совпадает с NULLCФильтр
WHERE cancelled_at <> NULL отберёт строки, где значение поля не равно NULLDФильтр
WHERE cancelled_at IS NOT NULL оставит отменённые строки с датой отменыПравильный ответ. Чтобы отобрать строки с пропуском, используйте
IS NULL, а не сравнение через = или <>.Разбор
Условие cancelled_at IS NULL вернёт TRUE для строк, где поля даты отмены нет, то есть для активных заказов. Сравнения вида = NULL или <> NULL всегда возвращают UNKNOWN, а не TRUE, поэтому такие фильтры дают пустой результат. Фильтр IS NOT NULL, наоборот, оставит только отменённые строки.
Проверь себя · 1/3разбор после ответа
В таблице
payments нужно выбрать платежи из России (country = 'RU') со статусом либо 'failed', либо 'chargeback'. Какой WHERE корректный?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям нужны только идентификатор пользователя `user_id` и дата `signup_at` из таблицы пользователей. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в нём нет `ORDER BY`?
- Все вопросы по «Основы SQL-запросов» →