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