На технических собеседованиях вопросы про индексы задают регулярно — и не только DBA. Системный аналитик, архитектор и даже старший бизнес-аналитик должен уметь объяснить, почему на определённом запросе «всё лагает», и предложить решение. Именно здесь часто ждут ответ про индексы. Блок про индексы обычно идет после общего блока про базы данных и до блока с написанием SQL запросов. Что такое индекс? Отдельная структура, которая позволяет базе не читать всю таблицу, а сразу находить нужные строки. Как содержание в книге. Главный компромисс индексов 🟢 SELECT работает быстрее 🔴 INSERT / UPDATE / DELETE медленнее, каждый индекс надо обновлять при каждом изменении строки Какие бывают типы индексов ➖B-tree — универсальный, работает для =, <, >, BETWEEN, ORDER BY. По умолчанию в большинстве СУБД ➖Hash — только точное равенство =, очень быстро, но больше ни для чего ➖GIN — массивы, JSONB, полнотекстовый поиск ➖BRIN — огромные таблицы с монотонной вставкой (логи, события) ➖Составной — нес
Индексы в базах данных — шпаргалка для системного аналитика
СегодняСегодня
1 мин