Нужно получить 5 самых дешёвых товаров категории 'electronics' из таблицы products. Какой запрос верный?
A
SELECT product_id, price FROM products WHERE category = 'electronics' ORDER BY price ASC LIMIT 5B
SELECT product_id, price FROM products WHERE category = 'electronics' ORDER BY price DESC LIMIT 5C
SELECT product_id, price FROM products ORDER BY price ASC LIMIT 5D
SELECT product_id, price FROM products WHERE category = 'electronics' LIMIT 5Правильный ответ. Чтобы взять «топ-N по критерию», нужна сортировка по критерию и
LIMIT после неё.Разбор
Сначала отфильтровываем нужную категорию через WHERE category = 'electronics'. Затем сортируем по цене по возрастанию, чтобы дешёвые были сверху: ORDER BY price ASC. И берём первые 5 строк через LIMIT 5. Если убрать ORDER BY, то LIMIT 5 не гарантирует, что это будут самые дешёвые.
Проверь себя · 1/3разбор после ответа
В таблице
orders нужно вывести заказы так, чтобы сначала шли самые дорогие (amount), а при одинаковой сумме — более ранние по created_at (чтобы вверху был «первый» из одинаковых). Какой ORDER BY подходит?Ещё вопросы по теме «Основы 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-запросов» →