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_schemaALTER 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语句。