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指示该操作符可以支持合并连接。只能启用,不能禁用。
有关更多信息,请参阅 第 36.14 节 和 第 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 语句。