codecamp

PostgreSQL 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);

兼容性

在 SQL 标准中没有ALTER OPERATOR语句。


PostgreSQL ALTER MATERIALIZED VIEW
PostgreSQL ALTER OPERATOR CLASS
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

PostgreSQL SQL语言

PostgreSQL 服务器管理

PostgreSQL 客户端接口

PostgreSQL 服务器编程

PostgreSQL 参考

PostgreSQL 内部

PostgreSQL 附录

PostgreSQL 参考书目

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }