Вы строите выдачу «последние заказы» и используете LIMIT 50. Поле created_at не уникально (много заказов в одну секунду). Какой ORDER BY лучше, чтобы порядок был детерминированным?

AORDER BY created_at DESC
BORDER BY created_at DESC, order_id DESC
CORDER BY order_id DESC, created_at DESC
DORDER 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 в Telegram

Ещё вопросы по теме «Основы SQL-запросов»