ALTER OPERATOR
ALTER OPERATOR — изменить определение оператора
Синтаксис
ALTER OPERATORимя
( {тип_слева
| NONE } ,тип_справа
) OWNER TO {новый_владелец
| CURRENT_ROLE | CURRENT_USER | SESSION_USER } ALTER OPERATORимя
( {тип_слева
| NONE } ,тип_справа
) SET SCHEMAновая_схема
ALTER OPERATORимя
( {тип_слева
| NONE } ,тип_справа
) SET ( { RESTRICT = {процедура_ограничения
| NONE } | JOIN = {процедура_соединения
| NONE } } [, ... ] )
Описание
ALTER OPERATOR
изменяет определение оператора.
Выполнить ALTER OPERATOR
может только владелец соответствующего оператора. Чтобы сменить владельца, необходимо быть непосредственным или опосредованным членом новой роли-владельца, а эта роль должна иметь право CREATE
в схеме оператора. (С такими ограничениями при смене владельца не происходит ничего такого, что нельзя было бы сделать, имея право удалить и вновь создать оператор. Однако суперпользователь может сменить владельца оператора в любом случае.)
Параметры
имя
Имя существующего оператора (возможно, дополненное схемой).
тип_слева
Тип данных левого операнда оператора; если у оператора нет левого операнда, укажите
NONE
.тип_справа
Тип данных правого операнда оператора.
новый_владелец
Новый владелец оператора.
новая_схема
Новая схема оператора.
процедура_ограничения
Функция оценки избирательности ограничения для данного оператора; значение NONE удаляет существующую функцию оценки.
процедура_соединения
Функция оценки избирательности соединения для этого оператора; значение NONE удаляет существующую функцию оценки.
Примеры
Смена владельца нестандартного оператора a @@ b
для типа text
:
ALTER OPERATOR @@ (text, text) OWNER TO joe;
Смена функций оценки избирательности ограничения и соединения для нестандартного оператора a && b
для типа int[]
:
ALTER OPERATOR && (_int4, _int4) SET (RESTRICT = _int_contsel, JOIN = _int_contjoinsel);
Совместимость
Команда ALTER OPERATOR
отсутствует в стандарте SQL.
См. также
CREATE OPERATOR, DROP OPERATORALTER OPERATOR
ALTER OPERATOR — change the definition of an operator
Synopsis
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_schema
ALTER OPERATORname
( {left_type
| NONE } ,right_type
) SET ( { RESTRICT = {res_proc
| NONE } | JOIN = {join_proc
| NONE } } [, ... ] )
Description
ALTER OPERATOR
changes the definition of an operator.
You must own the operator to use ALTER OPERATOR
. To alter the owner, you must also be a direct or indirect member of the new owning role, and that role must have CREATE
privilege on the operator's schema. (These restrictions enforce that altering the owner doesn't do anything you couldn't do by dropping and recreating the operator. However, a superuser can alter ownership of any operator anyway.)
Parameters
name
The name (optionally schema-qualified) of an existing operator.
left_type
The data type of the operator's left operand; write
NONE
if the operator has no left operand.right_type
The data type of the operator's right operand.
new_owner
The new owner of the operator.
new_schema
The new schema for the operator.
res_proc
The restriction selectivity estimator function for this operator; write NONE to remove existing selectivity estimator.
join_proc
The join selectivity estimator function for this operator; write NONE to remove existing selectivity estimator.
Examples
Change the owner of a custom operator a @@ b
for type text
:
ALTER OPERATOR @@ (text, text) OWNER TO joe;
Change the restriction and join selectivity estimator functions of a custom operator a && b
for type int[]
:
ALTER OPERATOR && (_int4, _int4) SET (RESTRICT = _int_contsel, JOIN = _int_contjoinsel);
Compatibility
There is no ALTER OPERATOR
statement in the SQL standard.