Вы делаете пагинацию по заказам: SELECT order_id, created_at FROM orders ORDER BY created_at DESC LIMIT 50 OFFSET 50. Иногда один и тот же order_id встречается на двух страницах. Какое улучшение проще всего сделать в рамках этих же операторов, чтобы порядок был более детерминированным?
AУвеличить
LIMIT до 100, чтобы реже перелистывать страницыBУбрать
OFFSET, оставив только LIMIT 50CДобавить
WHERE created_at IS NOT NULL, чтобы исключить пропускиD
ORDER BY created_at DESC, order_id DESCПравильный ответ. Добавляйте уникальный tie-breaker в
ORDER BY, если первый столбец сортировки не уникален.Разбор
Если created_at повторяется у многих заказов, то порядок строк с одинаковым временем может «плавать». Это особенно заметно при LIMIT/OFFSET, когда граница страницы проходит внутри группы одинаковых значений. Добавив уникальный столбец в сортировку, например order_id, вы фиксируете порядок: ORDER BY created_at DESC, order_id DESC. Это не решает всех проблем OFFSET при изменяющихся данных, но делает порядок воспроизводимым для одного и того же набора строк.
Проверь себя · 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-запросов» →