ALTER OPERATOR — 更改运算符定义
ALTER OPERATORname
( {left_type
| NONE } ,right_type
) OWNER TO {new_owner
| CURRENT_ROLE | CURRENT_USER | SESSION_USER } ALTER OPERATORname
( {left_type
| NONE } ,right_type
) SET SCHEMAnew_schema
ALTER OPERATORname
( {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
语句。