На большой таблице events запрос SELECT * FROM events ORDER BY created_at DESC LIMIT 100 неожиданно работает быстро. Какое объяснение наиболее вероятно при наличии индекса по created_at?

ALIMIT 100 отключает сортировку, поэтому ORDER BY не влияет.
BORDER BY в таких запросах игнорируется оптимизатором.
CПланировщик всегда использует хэширование, когда есть LIMIT.
DПлан может сделать Index Scan по индексу на created_at и взять первые строки без шага Sort.
Правильный ответ. ORDER BY + LIMIT часто ускоряется индексом по полю сортировки.

Разбор

Если есть подходящий индекс по created_at, планировщик может читать строки уже в нужном порядке и остановиться после LIMIT 100. Тогда дорогая операция Sort не нужна или становится значительно дешевле. Поэтому одинаковый запрос без индекса может быть на порядки медленнее.

Проверь себя · 1/3разбор после ответа
На большой таблице events запрос SELECT * FROM events ORDER BY created_at DESC LIMIT 100 неожиданно работает быстро. Какое объяснение наиболее вероятно при наличии индекса по created_at?
Тренировать SQL в Telegram

Ещё вопросы по теме «EXPLAIN и оптимизация»