ALTER OPERATOR
ALTER OPERATOR — 更改一个操作符的定义
大纲
ALTER OPERATORname
( {left_type
| NONE } , {right_type
| NONE } ) OWNER TO {new_owner
| CURRENT_USER | SESSION_USER } ALTER OPERATORname
( {left_type
| NONE } , {right_type
| NONE } ) SET SCHEMAnew_schema
ALTER OPERATORname
( {left_type
| NONE } , {right_type
| NONE } ) SET ( { RESTRICT = {res_proc
| NONE } | JOIN = {join_proc
| NONE } } [, ... ] )
描述
ALTER OPERATOR
更改一个操作符的定义。
要使用ALTER OPERATOR
,你必须拥有该操作符。要更改拥有者,
你还必须是新拥有角色的一个直接或者间接成员,并且该角色必须具有该操作符所在
模式上的CREATE
特权(这些限制强制修改拥有者不能做一些通过
删除和重建操作符做不到的事情。不过,一个超级用户怎么都能更改任何操作符的所
有权。)。
参数
name
一个现有操作符的名称(可以是模式限定的)。
left_type
该操作符左操作数的数据类型,如果该操作符没有左操作数可以写成
NONE
。right_type
该操作符右操作数的数据类型,如果该操作符没有右操作数可以写成
NONE
。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
语句。
文章转载自PostgreSQL全球开发组,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。