DROP OPERATOR CLASS

Name

DROP OPERATOR CLASS -- 删除一个操作符类

Synopsis

DROP OPERATOR CLASS [ IF EXISTS ] name USING index_method [ CASCADE | RESTRICT ]

描述

DROP OPERATOR CLASS删除一个现有操作符类。要执行这条命令,你必须是此操作符类的所有者。

DROP OPERATOR CLASS不会删除类引用的任何操作符和函数。 若有任何依赖该操作符类的索引,你将需要声明CASCADE来完成删除操作。

参数

IF EXISTS

如果指定的操作符类不存在,那么发出一个notice而不是抛出一个错误。

name

一个现存操作符类的名字(可以用模式修饰)。

index_method

操作符类所引用的索引访问方法的名字。

CASCADE

级联删除依赖于该操作符类的对象。

RESTRICT

如果有任何依赖对象存在,则拒绝删除此操作符类。这个行为是缺省。

注意

DROP OPERATOR CLASS不会删除包含类的操作符系,即使在系中没留下任何东西 (尤其,在系由CREATE OPERATOR CLASS隐式创建的情况)。一个空的操作符系是 无害的,但是为了整洁您可能希望通过DROP OPERATOR FAMILY删除系; 在起初使用DROP OPERATOR FAMILY可能会更好。

例子

删除B-tree操作符类widget_ops

DROP OPERATOR CLASS widget_ops USING btree;

如果有任何现存的索引使用这个操作符类,那么这条命令将不能执行。 增加一个CASCADE删除这样的索引以及这个操作符类。

兼容性

SQL标准里没有DROP OPERATOR CLASS语句。

又见

ALTER OPERATOR CLASS, CREATE OPERATOR CLASS, DROP OPERATOR FAMILY