Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17

ALTER OPERATOR

ALTER OPERATOR — 更改运算符定义

语法

ALTER OPERATOR name ( { left_type | NONE } , right_type )
    OWNER TO { new_owner | CURRENT_ROLE | CURRENT_USER | SESSION_USER }

ALTER OPERATOR name ( { left_type | NONE } , right_type )
    SET SCHEMA new_schema

ALTER OPERATOR name ( { left_type | NONE } , right_type )
    SET ( {  RESTRICT = { res_proc | NONE }
           | JOIN = { join_proc | NONE }
           | COMMUTATOR = com_op
           | NEGATOR = neg_op
           | HASHES
           | MERGES
          } [, ... ] )

描述

ALTER OPERATOR 修改运算符的定义。

若要使用 ALTER OPERATOR,您必须拥有 operator 的所有权。要变更所有者,您必须能够对新所有者角色 SET ROLE,该角色必须对 operator 的架构具有 CREATE 权限。(这些限制强制要求变更所有者不能通过删除和重新创建 operator 来执行您无法执行的操作。但是,无论如何超级用户都可以变更任何 operator 的所有权。)

参数

name

现有 operator 的名称(可选方案限定)。

left_type

operator 左操作数的数据类型;如果 operator 没有左操作数,请写 NONE

right_type

operator 右操作数的数据类型。

new_owner

operator 的新所有者。

new_schema

operator 的新架构。

res_proc

此 operator 的限制选择性估计器函数;写 NONE 以删除现有的选择性估计器。

join_proc

此 operator 的联接选择性估计器函数;写 NONE 以删除现有的选择性估计器。

com_op

此 operator 的换向者。仅当 operator 没有现有的换向者时才能对其进行更改。

neg_op

此 operator 的求反者。仅当 operator 没有现有的求反者时才能对其进行更改。

HASHES

表明此 operator 可支持哈希联接。只能启用,不能禁用。

MERGES

表明此 operator 可支持合并联接。只能启用,不能禁用。

注释

有关更多信息,请参阅 第 36.14 节第 36.15 节

由于换向者以彼此是换向者的成对出现,因此 ALTER OPERATOR SET COMMUTATOR 还将设置 com_op 的换向者为目标运算符。同样,ALTER OPERATOR SET NEGATOR 还将设置 neg_op 的求反者为目标运算符。因此,您还必须拥有换向器或求反者运算符以及目标运算符。

示例

更改类型为 text 的自定义 operator a @@ b 的所有者

ALTER OPERATOR @@ (text, text) OWNER TO joe;

更改类型为 int[] 的自定义 operator a && b 的限制和联接选择性估计器函数

ALTER OPERATOR && (int[], int[]) SET (RESTRICT = _int_contsel, JOIN = _int_contjoinsel);

&& 运算符标记为其自己的换向者

ALTER OPERATOR && (int[], int[]) SET (COMMUTATOR = &&);

兼容性

SQL 标准中没有 ALTER OPERATOR 语句。

另请参见

CREATE OPERATORDROP OPERATOR