DROP INDEX — удалить индекс
DROP INDEX [ CONCURRENTLY ] [ IF EXISTS ] имя [, ...] [ CASCADE | RESTRICT ]DROP INDEX удаляет существующий индекс из базы данных. Выполнить эту команду может только владелец индекса.
CONCURRENTLYС этим указанием индекс удаляется, не блокируя одновременные операции выборки, добавления, изменения и удаления данных в таблице индекса. Обычный оператор DROP INDEX запрашивает блокировку ACCESS EXCLUSIVE для таблицы, не допуская другие обращения к ней до завершения удаления. Если же добавлено это указание, команда, напротив, будет ждать завершения конфликтующих транзакций.
Применяя это указание, надо учитывать несколько особенностей. В частности, при этом можно задать имя только одного индекса, а параметр CASCADE не поддерживается. (Таким образом, индекс, поддерживающий ограничение UNIQUE или PRIMARY KEY, так удалить нельзя.) Кроме того, обычную команду DROP INDEX можно выполнить в блоке транзакции, а DROP INDEX CONCURRENTLY — нет. Наконец, с этим указанием нельзя удалить индексы секционированных таблиц.
Для временных таблиц DROP INDEX всегда выполняется более простым, неблокирующим способом, так как они не могут использоваться никакими другими сеансами.
IF EXISTSНе считать ошибкой, если индекс не существует. В этом случае будет выдано замечание.
имяИмя (возможно, дополненное схемой) индекса, подлежащего удалению.
CASCADEАвтоматически удалять объекты, зависящие от данного индекса, и, в свою очередь, все зависящие от них объекты (см. Раздел 5.15).
RESTRICTОтказать в удалении индекса, если от него зависят какие-либо объекты. Это поведение по умолчанию.
Эта команда удалит индекс title_idx:
DROP INDEX title_idx;
DROP INDEX является языковым расширением Postgres Pro Shardman. Средства обеспечения индексов в стандарте SQL не описаны.