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

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 }
         } [, ... ] )

说明

ALTER OPERATOR 更改运算符的定义。

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

参数

name

现有运算符的名称(可选架构限定)。

left_type

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

right_type

运算符右操作数的数据类型。

new_owner

运算符的新所有者。

new_schema

运算符的新架构。

res_proc

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

join_proc

此运算符的连接选择性估算器函数;写 NONE 以删除现有的选择性估算器。

示例

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

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

更改类型为 int[] 的自定义运算符 a && b 的限制和连接选择性估算器函数

ALTER OPERATOR && (_int4, _int4) SET (RESTRICT = _int_contsel, JOIN = _int_contjoinsel);

兼容性

SQL 标准中没有 ALTER OPERATOR 语句。

另请参阅

CREATE OPERATORDROP OPERATOR