Вы строите выдачу «последние заказы» и используете LIMIT 50. Поле created_at не уникально (много заказов в одну секунду). Какой ORDER BY лучше, чтобы порядок был детерминированным?
A
ORDER BY created_at DESCB
ORDER BY created_at DESC, order_id DESCC
ORDER BY order_id DESC, created_at DESCD
ORDER BY created_at ASC, order_id DESCПравильный ответ. Если основной ключ сортировки не уникален, добавляйте второй (обычно уникальный) столбец как tie-breaker.
Разбор
При ORDER BY created_at DESC строки с одинаковым created_at могут возвращаться в разном порядке, а это влияет на LIMIT и пагинацию. Добавив второй столбец, который однозначно различает строки (например, order_id), вы фиксируете порядок: ORDER BY created_at DESC, order_id DESC. Тогда «верхние 50» будут воспроизводимыми при повторных запросах к тем же данным.
Проверь себя · 1/3разбор после ответа
Нужно вывести только оплаченные заказы (
status = 'paid') и отсортировать их по времени создания от новых к старым. Какой запрос соответствует задаче?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям вам нужны только `user_id` и `signup_at` из таблицы `users`. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в запросе нет `ORDER BY`?
- Нужно показать 3-ю страницу каталога товаров: по 20 товаров на страницу, сортировка по цене по возрастанию (`price`). Какой запрос корректный?
- Все вопросы по «Основы SQL-запросов» →