大纲
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
权限。
(这些限制确保更改所有者不会做任何您不能通过删除和重新创建操作符
来完成的事情。然而,超级用户仍然可以更改任何操作符的所有权。)
示例
更改类型text
的一个自定义操作符a @@ b
的拥有者:
ALTER OPERATOR @@ (text, text) OWNER TO joe;
更改类型int[]
的自定义操作符a && b
的
约束和连接选择度估算器函数:
ALTER OPERATOR && (_int4, _int4) SET (RESTRICT = _int_contsel, JOIN = _int_contjoinsel);