Основные тезисы

1) Индексы ускоряют поиск данных в таблице, но замедляют вставку и редактирование (если изменяются столбцы задействованные хотя бы в одном индексе).
2) При создании индексов стоит учитывать:
2.1) Как часто с данной таблицей будут производиться операции чтения/записи.
2.2) Какие конкретно запросы будут выполняться. (по каким полям будет идти поиск, соединение, группировка, сортировка: WHERE, JOIN)
2.3) Предполагаемые размеры таблицы.
3) Также в определенных запросах индекс может использоваться для более быстрого выполнения операции сортировки, группировки, соединения.

Индекс - отдельная вспомогательная структура данных (по отношению к таблице), которая содержит метаданные, чтобы ускорить поисковые запросы.
Данные индексов также подлежат хранению, как и данные таблиц.

Кластерный (кластеризованный) индекс
Данный индекс определяет порядок строк в таблице, может существовать только в единственном экземпляре.
При вставке новой записи в таблицу рассчитывается значение кластерного индекса для новой строки, на основе которого выполняется вставка в имеющийся набор строк.
Для таблицы может быть только 1 кластерный индекс. Обычно совпадает с первичным ключом. Также в таблице может отсутствовать кластерный индекса (строки будут расположены в порядке их добавления).
Postgres не содержит кластерных индексов
Покрывающий индекс
 Включение в индекс столбцов, которые не будут использоваться при поиске по индексу. Но позволят получить данные этих столбцов, без обращений к таблице.
 should primary key be included in regular indexes (MS SQL-Server)
https://stackoverflow.com/questions/3594661/should-primary-key-be-included-in-regular-indexes

Должен ли покрывающий индекс включать в себя primary key? (postgresql)
https://ru.stackoverflow.com/questions/899825/Должен-ли-покрывающий-индекс-включать-в-себя-primary-key
Обслуживание
Оценка состояния индексов. Поддержка индексов в актуальном состоянии.
Критерии состояния индекса (фрагментация).
Действия по обслуживанию индекса (перестроение, пересоздание).
Fill factor
https://habr.com/ru/post/570722/
Умещается ли индекс целиком в оперативной памятиЕсли индекс часто используется и при этом не умещается в оперативной памяти, то это может сильно понизить производительность запросов из-за частых обращений к диску.
Вспомогательные темы:
1) Архивирование данных 
2) Фильтрующий индексСоздание фильтрующих индексов, которые будут покрывать частые сценарии, но будут покрывать не всю таблицу, а только необходимые данные. (Также сценарий окна, когда для обработки нужны только определенные данные).

Внутренние ссылки:

Дочерние страницы:
Обратные ссылки:

Ссылки:

MSSQL 14 вопросов об индексах в SQL Server, которые вы стеснялись задать
https://habr.com/ru/post/247373/
 Основы индексов в Microsoft SQL Server
https://info-comp.ru/programmirovanie/575-index-basics-in-ms-sql-server.html
 Обслуживание индексов и статистик MS SQL Server
https://infostart.ru/public/256292/
   
PostgreSQLPostgreSQL. Индексы 
Теги: