Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

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

Почему hash-индексы не подходят для range-запросов?

Вопрос проверяет понимание устройства hash-индексов и их ограничений при выполнении диапазонных запросов.

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

Hash-индексы работают только на точное совпадение значений. Они не сохраняют порядок ключей, поэтому не могут эффективно обрабатывать запросы вида «больше», «меньше» или «между». Для range-запросов нужны упорядоченные структуры, например B-tree.

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

Hash-индексы оптимизированы под один конкретный сценарий — быстрый поиск по равенству.

Определение

Hash-индекс — это индекс, который сопоставляет ключ хеш-значению и использует его для быстрого поиска по точному совпадению.

Как работает hash-индекс

  1. вычисляется хеш от значения,

  2. по хешу выбирается бакет,

  3. внутри бакета ищется точное значение.

Почему range-запросы невозможны

  1. порядок значений не сохраняется,

  2. невозможно перейти к «следующему» ключу,

  3. диапазон требует проверки всех бакетов.

Пример запроса

SELECT * FROM orders WHERE amount BETWEEN 100 AND 200;

Для такого запроса hash-индекс бесполезен.

Подходящая альтернатива

  • B-tree индексы,

  • упорядоченные структуры данных.

Вывод

Hash-индексы не подходят для range-запросов, потому что не поддерживают порядок значений и работают только с операциями равенства.

  • Аватар

    Python Guru

    Sergey Filichkin

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

Уровень

  • Рейтинг:

    5

  • Сложность:

    6

Навыки

  • Postgres

    Postgres

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

#hash

#index

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

  • Аватар

    Python Guru

    Sergey Filichkin

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