DROP INDEX
功能描述
删除一个索引。
注意事项
索引的所有者、索引所在模式的所有者、拥有索引所在表的INDEX权限的用户或者被授予了DROP ANY INDEX权限的用户可以执行该操作,三权分立关闭时的系统管理员默认拥有此权限。
语法格式
1 2 |
DROP INDEX [ IF EXISTS ] index_name [, ...] [ CASCADE | RESTRICT ]; |

参数说明
- IF EXISTS
判断指定的索引是否存在。
- 如果指定的索引存在,则删除成功。
- 如果指定的索引不存在,不会进行删除操作,仅产生一个NOTICE提示,用于告知指定索引不存在。
- index_name
要删除的索引名。
取值范围:已存在的索引。
- CASCADE | RESTRICT
可选,是否级联删除依赖于该索引的对象。未指定时,默认为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;