ALTER OPERATOR (original) (raw)

This documentation is for an unsupported version of PostgreSQL.
You may want to view the same page for thecurrent version, or one of the other supported versions listed above instead.

ALTER OPERATOR — change the definition of an operator

Synopsis

ALTER OPERATOR name ( { lefttype | NONE } , { righttype | NONE } ) OWNER TO { newowner | CURRENT_USER | SESSION_USER }

ALTER OPERATOR name ( { lefttype | NONE } , { righttype | NONE } ) SET SCHEMA newschema

ALTER OPERATOR name ( { lefttype | NONE } , { righttype | NONE } ) SET ( { RESTRICT = { resproc | NONE } | JOIN = { joinproc | 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.

lefttype

The data type of the operator's left operand; write NONE if the operator has no left operand.

righttype

The data type of the operator's right operand; write NONE if the operator has no right operand.

newowner

The new owner of the operator.

newschema

The new schema for the operator.

resproc

The restriction selectivity estimator function for this operator; write NONE to remove existing selectivity estimator.

joinproc

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.