DROP OPERATOR CLASS — 删除一个操作符类
DROP OPERATOR CLASS [ IF EXISTS ]nameUSINGindex_method[ CASCADE | RESTRICT ]
DROP OPERATOR CLASS 删除一个现有的操作符类。要执行此命令,您必须是该操作符类的所有者。
DROP OPERATOR CLASS 不会删除类所引用的任何操作符或函数。如果存在任何依赖于该操作符类的索引,则您需要指定 CASCADE 才能完成删除。
IF EXISTS如果操作符类不存在,则不报错。在这种情况下会发出一个通知。
name一个现有操作符类的名称(可选择模式限定)。
index_method该操作符类适用的索引访问方法的名称。
CASCADE自动删除依赖于操作符类的对象(例如索引),以及反过来依赖于这些对象的所有对象(参见 第 5.15 节)。
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 语句。