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自动删除依赖于该操作符类的对象(例如索引),以及进一步依赖于这些对象的所有对象 (参见Section 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语句。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。