DROP INDEX
功能描述
删除索引。
注意事项
- 索引的所有者、索引所在模式的所有者、拥有索引所在表的INDEX权限的用户或者被授予了DROP ANY INDEX权限的用户有权限执行DROP INDEX命令,三权分立关闭时,系统管理员默认拥有此权限。
- 对于全局临时表,当某个会话已经初始化了全局临时表对象(包括创建全局临时表和第一次向全局临时表内插入数据)时,其他会话无法执行该表上索引的删除操作。
语法格式
DROP INDEX [ CONCURRENTLY ] [ IF EXISTS ] index_name [, ...] [ CASCADE | RESTRICT ];
参数说明
- CONCURRENTLY
以不加锁的方式删除索引。删除索引时,一般会阻塞其他语句对该索引所依赖表的访问。加此关键字,可在删除过程中避免阻塞。
此选项只能指定一个索引的名称, 并且不支持CASCADE选项。
普通DROP INDEX命令可以在事务内执行,但是DROP INDEX CONCURRENTLY不可以在事务内执行。
- IF EXISTS
如果指定的索引不存在,则发出一个notice而不是抛出一个error。
- index_name
要删除的索引名。
取值范围:已存在的索引。
- CASCADE | RESTRICT
- CASCADE:表示允许级联删除依赖于该索引的对象。
- RESTRICT:表示有依赖于此索引的对象存在时,该索引无法被删除。此选项为缺省值。
示例
--创建表。 gaussdb=# CREATE TABLE test1_index (id INT, name VARCHAR(20)); --创建索引。 gaussdb=# CREATE INDEX idx_test1 (id); --删除索引。 gaussdb=# DROP INDEX IF EXISTS idx_test1 CASCADE; --删除表。 gaussdb=# DROP TABLE test1_index;