ИндексыПродвинутый
Составной индекс
Индекс по нескольким колонкам. Порядок колонок критически важен.
Синтаксис
CREATE INDEX ON table (col1, col2, col3);
Объяснение
Составной индекс по (a, b, c) работает для условий: WHERE a=..., WHERE a=... AND b=..., WHERE a=... AND b=... AND c=... Но НЕ работает для WHERE b=... без a.
Правило левого префикса: запрос должен включать первые N колонок индекса по порядку.
Порядок: сначала колонки равенства (=), потом диапазона (<, >). INDEX(status, created_at) быстрее для WHERE status='paid' AND created_at > '2024-01-01'.
Пример
-- Эффективный составной индекс CREATE INDEX ON orders (user_id, status, created_at DESC); -- Использует индекс: SELECT * FROM orders WHERE user_id = 1 AND status = 'paid' ORDER BY created_at DESC; -- НЕ использует (нет первой колонки): SELECT * FROM orders WHERE status = 'paid';
Связанные термины
EXPLAIN / EXPLAIN ANALYZEEXPLAIN показывает план выполнения запроса. EXPLAIN ANALYZE выполняет запрос и показывает реальное время.INDEX (индекс)Структура данных, ускоряющая поиск строк по значению колонки.Partial Index (частичный индекс)Индекс с условием WHERE — индексирует только часть строк таблицы.
Анекдоты по теме
Индекс говорит таблице: — Милая, ты знаешь, я тебя ускоряю в 1000 раз! Таблица (тяжело вздыхая): — А я из-за тебя при каждой вставке торможу. Ты меня перестраиваешь. Мы в toxic relationship. Индекс: — Ничего, я кластерный. Без меня ты вообще куча мусора на диске.
— Как понять, что ты начинающий? — Ты ставишь LIMIT 10, а база всё равно думает минуту. Опытный ставит правильный индекс и не ждёт.
— B-tree, Hash, GIN, GiST, BRIN — как выбрать? — B-tree: всё что угодно, сравнения <, >, =. По умолчанию. — Hash: только = (редко нужен). — GIN: массивы, JSONB, full-text. — GiST: геометрия, диапазоны. — BRIN: огромные таблицы с физически упорядоченными данными (даты логов).