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 } | COMMUTATOR =com_op| NEGATOR =neg_op| HASHES | MERGES } [, ... ] )
ALTER OPERATOR更改一个操作符的定义。
要使用ALTER OPERATOR,你必须拥有该操作符。 要修改拥有者,你必须能够对新拥有角色执行SET ROLE, 并且该角色必须在该操作符所在模式上具有CREATE权限。 (这些限制确保更改拥有者不会让你做到那些不能通过删除并重建该操作符来做到的事情。 不过,超级用户始终可以更改任何操作符的所有权。)
name #一个现有操作符的名称(可以是模式限定的)。
left_type #该操作符左操作数的数据类型;如果该操作符没有左操作数,请写 NONE。
right_type #该操作符右操作数的数据类型。
new_owner #该操作符的新拥有者。
new_schema #该操作符的新模式。
res_proc #该操作符的限制选择度估算函数;写成NONE可移除现有的选择度估算器。
join_proc #该操作符的连接选择度估算函数;写成NONE可移除现有的选择度估算器。
com_op #该操作符的交换子。只有当该操作符当前没有交换子时,才能修改此项。
neg_op #该操作符的求反器。只有当该操作符当前没有求反器时,才能修改此项。
HASHES #表示该操作符可以支持哈希连接。该属性只能启用,不能禁用。
MERGES #表示该操作符可以支持归并连接。该属性只能启用,不能禁用。
更多信息请参见Section 36.14和 Section 36.15。
由于交换子总是成对出现、彼此互为交换子, ALTER OPERATOR SET COMMUTATOR也会把 com_op的交换子设置为目标操作符。 同样,ALTER OPERATOR SET NEGATOR也会把 neg_op的求反器设置为目标操作符。 因此,你不仅必须拥有目标操作符,也必须拥有其交换子或求反器操作符。
更改类型text上的自定义操作符a @@ b的拥有者:
ALTER OPERATOR @@ (text, text) OWNER TO joe;
更改类型int[]上的自定义操作符a && b的 限制和连接选择度估算函数:
ALTER OPERATOR && (int[], int[]) SET (RESTRICT = _int_contsel, JOIN = _int_contjoinsel);
将&&操作符标记为其自身的交换子:
ALTER OPERATOR && (int[], int[]) SET (COMMUTATOR = &&);
在 SQL 标准中没有ALTER OPERATOR语句。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。