Что вернёт запрос: 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 в Telegram

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