Назад к вопросам
Junior — Middle
71
Каким образом можно создать индекс для колонки большой таблицы без блокировки всей таблицы?
Компании, где спрашивали
Lamoda Tech
Ответ от нейросети
sobes.tech AI
Для создания индекса в большой таблице без блокировки всей таблицы в PostgreSQL можно использовать опцию CONCURRENTLY:
CREATE INDEX CONCURRENTLY index_name ON table_name(column_name);
Этот режим позволяет создавать индекс без эксклюзивной блокировки таблицы, что значит, что другие операции записи и чтения могут продолжаться. Однако создание индекса таким способом занимает больше времени и требует больше ресурсов.
Важно: нельзя использовать CONCURRENTLY внутри транзакции, команда должна выполняться отдельно.
В других СУБД могут быть похожие механизмы, например, в MySQL с InnoDB можно использовать ALGORITHM=INPLACE для создания индексов без полной блокировки таблицы.