Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: index, selectivity

На какие столбцы создавать индексы? Критерии выбора (селективность, составные индексы).

Вопрос объясняет принципы выбора столбцов для индексации.

Короткий ответ

Индексы нужны для:

  • Столбцов с высокой селективностью (уникальные или почти уникальные значения).

  • Составных индексов под частые условия WHERE (порядок столбцов важен!).

Длинный ответ

Критерии:

  1. Селективность:

    • Хорошо: user_id (много уникальных значений).

    • Плохо: gender (мало вариантов).

  2. Составные индексы:

    • Создавайте для запросов с несколькими условиями:

    CREATE INDEX idx_profile_region ON profiles(region_id, status);
    • Порядок столбцов должен соответствовать порядку в WHERE.

  3. Использование в JOIN:

    • Индексируйте внешние ключи.

Когда не индексировать:

  • Часто обновляемые столбцы.

  • Маленькие таблицы (<10k записей).

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    1

  • Сложность:

    6

Навыки

  • Postgres

    Postgres

Ключевые слова

#index

#selectivity

Подпишись на Python Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.