В таблице orders нужно вывести заказы так, чтобы сначала шли самые дорогие (amount), а при одинаковой сумме — более ранние по created_at (чтобы вверху был «первый» из одинаковых). Какой ORDER BY подходит?
A
ORDER BY amount ASC, created_at ASCB
ORDER BY created_at ASC, amount DESCC
ORDER BY amount DESC, created_at ASCD
ORDER BY amount DESC, created_at DESCПравильный ответ. В
ORDER BY можно задавать приоритет столбцов и направления сортировки для каждого столбца.Разбор
Основной критерий — сумма заказа, поэтому amount должен идти первым. «Самые дорогие сверху» означает amount DESC. Вторичный критерий применяется только при равном amount: «более ранние выше» означает created_at ASC. Итог: ORDER BY amount DESC, created_at ASC.
Проверь себя · 1/3разбор после ответа
Нужно показать 3-ю страницу каталога товаров: по 20 товаров на страницу, сортировка по цене по возрастанию (
price). Какой запрос корректный?Ещё вопросы по теме «Основы 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-запросов» →