Какой набор строк вернёт условие WHERE is_active = true AND NOT (country = 'RU' AND age > 25)?
AАктивных пользователей из России старше 25 лет, у которых есть подписка на сервис
BВсех пользователей из России независимо от статуса активности и возраста
CАктивных пользователей не из России или активных пользователей из России от 25 лет и младше
DНеактивных пользователей из России, а также всех пользователей младше 25 лет
Правильный ответ.
NOT инвертирует выражение в скобках: NOT (A AND B) эквивалентно NOT A OR NOT B по закону де Моргана.Разбор
Условие разбирается так: is_active = true — берём только активных. Далее NOT (country = 'RU' AND age > 25) по закону де Моргана превращается в country <> 'RU' OR age <= 25. Итого: активные пользователи, которые либо не из России, либо из России, но возрастом 25 лет и младше. Пользователь из России с возрастом 30 лет не пройдёт фильтр.
Проверь себя · 1/3разбор после ответа
В таблице
orders поле cancelled_at заполняется только для отменённых заказов, а для активных — NULL. Какой фильтр выберет активные (не отменённые) заказы?Ещё вопросы по теме «Основы 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-запросов» →