ALTER OPERATOR
ALTER OPERATOR — изменить определение оператора
Синтаксис
ALTER OPERATORимя
( {тип_слева
| NONE } , {тип_справа
| NONE } ) OWNER TO {новый_владелец
| CURRENT_USER | SESSION_USER } ALTER OPERATORимя
( {тип_слева
| NONE } , {тип_справа
| NONE } ) SET SCHEMAновая_схема
ALTER OPERATORимя
( {тип_слева
| NONE } , {тип_справа
| NONE } ) SET ( { RESTRICT = {процедура_ограничения
| NONE } | JOIN = {процедура_соединения
| NONE } } [, ... ] )
Описание
ALTER OPERATOR
изменяет определение оператора.
Выполнить ALTER OPERATOR
может только владелец соответствующего оператора. Чтобы сменить владельца, необходимо быть непосредственным или опосредованным членом новой роли-владельца, а эта роль должна иметь право CREATE
в схеме оператора. (С такими ограничениями при смене владельца не происходит ничего такого, что нельзя было бы сделать, имея право удалить и вновь создать оператор. Однако суперпользователь может сменить владельца оператора в любом случае.)
Параметры
имя
Имя существующего оператора (возможно, дополненное схемой).
тип_слева
Тип данных левого операнда оператора; если у оператора нет левого операнда, укажите
NONE
.тип_справа
Тип данных правого операнда оператора; если у оператора нет правого операнда, укажите
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 OPERATORDROP MATERIALIZED VIEW
DROP MATERIALIZED VIEW — remove a materialized view
Synopsis
DROP MATERIALIZED VIEW [ IF EXISTS ] name
[, ...] [ CASCADE | RESTRICT ]
Description
DROP MATERIALIZED VIEW
drops an existing materialized view. To execute this command you must be the owner of the materialized view.
Parameters
IF EXISTS
Do not throw an error if the materialized view does not exist. A notice is issued in this case.
name
The name (optionally schema-qualified) of the materialized view to remove.
CASCADE
Automatically drop objects that depend on the materialized view (such as other materialized views, or regular views), and in turn all objects that depend on those objects (see Section 5.14).
RESTRICT
Refuse to drop the materialized view if any objects depend on it. This is the default.
Examples
This command will remove the materialized view called order_summary
:
DROP MATERIALIZED VIEW order_summary;
Compatibility
DROP MATERIALIZED VIEW
is a Postgres Pro extension.