2024年9月26日: PostgreSQL 17 发布!
支持版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:devel
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0

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。要更改所有者,您必须能够将 SET ROLE 设置为新的拥有角色,并且该角色必须对运算符的模式具有 CREATE 权限。(这些限制强制执行更改所有者不会执行您无法通过删除和重新创建运算符执行的操作。但是,超级用户可以随时更改任何运算符的所有权。)

参数

name

现有运算符的名称(可选地进行模式限定)。

left_type

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

right_type

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

new_owner

运算符的新所有者。

new_schema

运算符的新模式。

res_proc

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

join_proc

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

com_op

此运算符的交换子。只有在运算符没有现有交换子时才能更改。

neg_op

此运算符的否定符。只有在运算符没有现有否定符时才能更改。

HASHES

指示此运算符可以支持哈希连接。只能启用,不能禁用。

MERGES

指示此运算符可以支持合并连接。只能启用,不能禁用。

注释

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

由于交换子成对出现,并且彼此是交换子,因此 ALTER OPERATOR SET COMMUTATOR 也会将 com_op 的交换子设置为目标运算符。同样,ALTER OPERATOR SET NEGATOR 也会将 neg_op 的否定符设置为目标运算符。因此,您必须拥有交换子或否定符运算符以及目标运算符。

示例

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

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

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

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

&& 运算符标记为其自身的交换子

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

兼容性

SQL 标准中没有 ALTER OPERATOR 语句。

提交更正

如果您在文档中看到任何不正确的内容、与您对特定功能的体验不符的内容或需要进一步澄清的内容,请使用 此表单 报告文档问题。