暂无图片
暂无图片
1
暂无图片
暂无图片
暂无图片

Halo数据之SQL命令--ALTER OPERATOR

原创 贾桂军 2023-12-22
14973

ALTER OPERATOR

ALTER OPERATOR — 更改一个操作符的定义

 

大纲

ALTER OPERATOR name ( { left_type | NONE } , { right_type | NONE } )

OWNER TO { new_owner | CURRENT_USER | SESSION_USER }

ALTER OPERATOR name ( { left_type | NONE } , { right_type | NONE } )

SET SCHEMA new_schema

ALTER OPERATOR name ( { 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);

 

另见

CREATE OPERATOR, DROP OPERATOR

最后修改时间:2023-12-27 11:10:57
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论