Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Войти

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

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

© 2026 YeaHub

Документы

Медиа

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

Объясни разницу между индексами B-Tree, Hash и BRIN в Postgres. В каких случаях каждый оптимален?

Вопрос проверяет знание внутренних структур Postgres и умение выбирать индексы под задачу.

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

  • B-Tree — универсальный индекс для диапазонов и сортировки.

  • Hash — быстрый поиск по равенству, но ограниченный.

  • BRIN — очень компактный индекс для больших таблиц с упорядоченными данными.

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

B-Tree (по умолчанию):

  • Подходит для <, >, BETWEEN, ORDER BY.

  • Самый универсальный.

  • Хорошо работает на маленьких и средних таблицах.

Hash:

  • Оптимален для = (равенство).

  • Не поддерживает диапазоны.

  • В PG ≥ 10 поддерживает WAL и надёжен.

BRIN (Block Range Index):

  • Сохраняет статистику по блокам (минимум/максимум).

  • Работает на очень больших таблицах (миллиарды строк).

  • Подходит для данных с естественным порядком (дата, автоинкремент id).

Уровень

  • Рейтинг:

    5

  • Сложность:

    7

Навыки

  • Postgres

    Postgres

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

#postgres

#index

#btree

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