В таблице payments нужно выбрать платежи из России (country = 'RU') со статусом либо 'failed', либо 'chargeback'. Какой WHERE корректный?
A
WHERE country = 'RU' AND status = 'failed' OR status = 'chargeback'B
WHERE country = 'RU' AND (status = 'failed' OR status = 'chargeback')C
WHERE (country = 'RU' OR status = 'failed') AND status = 'chargeback'D
WHERE country = 'RU' OR status = 'failed' OR status = 'chargeback'Правильный ответ. Скобки фиксируют смысл: сначала объединяем допустимые статусы, затем применяем страну.
Разбор
Задача требует одновременно соблюдения страны и принадлежности статуса к одному из двух значений. Поэтому правильно: country = 'RU' AND (status = 'failed' OR status = 'chargeback'). Если убрать скобки, условие может начать пропускать все строки со статусом 'chargeback' из любых стран, что исказит выборку для анализа.
Проверь себя · 1/3разбор после ответа
Что сделает запрос
INSERT INTO archive (order_id, amount, status) SELECT order_id, amount, status FROM orders WHERE status = 'completed'?Ещё вопросы по теме «Основы 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-запросов» →