Что вернёт запрос: SELECT * FROM orders WHERE CASE WHEN status = 'shipped' THEN created_at > NOW() - INTERVAL '30 days' ELSE amount > 1000 END?
AЗапрос вернёт все заказы со статусом
'shipped' за последние 30 дней независимо от суммы заказаBЗапрос вернёт все заказы с суммой больше 1000 независимо от статуса и даты создания заказа
CЗапрос вернёт ошибку, потому что использовать
CASE WHEN внутри WHERE синтаксически нельзяDЗапрос вернёт заказы: отправленные за 30 дней или остальные с суммой больше 1000
Правильный ответ.
CASE WHEN в WHERE позволяет применять разные условия фильтрации в зависимости от значений строки.Разбор
Для каждой строки CASE проверяет статус: если 'shipped', применяется условие по дате (последние 30 дней); для остальных статусов — условие по сумме (больше 1000). Это паттерн условной фильтрации: разные строки проходят через разные правила. Такой подход встречается в аналитических запросах, когда логика фильтрации зависит от категории данных.
Проверь себя · 1/3разбор после ответа
Что произойдёт при выполнении запроса
SELECT product_id, price - cost AS margin FROM products, если столбцы price и cost числовые?Ещё вопросы по теме «Основы 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-запросов» →