ALTER PROCEDURE
ALTER PROCEDURE — изменить определение процедуры
Синтаксис
ALTER PROCEDURE имя [ ( [ [ режим_аргумента ] [ имя_аргумента ] тип_аргумента [, ...] ] ) ]
действие [ ... ] [ RESTRICT ]
ALTER PROCEDURE имя [ ( [ [ режим_аргумента ] [ имя_аргумента ] тип_аргумента [, ...] ] ) ]
RENAME TO новое_имя
ALTER PROCEDURE имя [ ( [ [ режим_аргумента ] [ имя_аргумента ] тип_аргумента [, ...] ] ) ]
OWNER TO { новый_владелец | CURRENT_ROLE | CURRENT_USER | SESSION_USER }
ALTER PROCEDURE имя [ ( [ [ режим_аргумента ] [ имя_аргумента ] тип_аргумента [, ...] ] ) ]
SET SCHEMA новая_схема
ALTER PROCEDURE имя [ ( [ [ режим_аргумента ] [ имя_аргумента ] тип_аргумента [, ...] ] ) ]
[ NO ] DEPENDS ON EXTENSION имя_расширения
где действием может быть:
[ EXTERNAL ] SECURITY INVOKER | [ EXTERNAL ] SECURITY DEFINER
SET параметр_конфигурации { TO | = } { значение | DEFAULT }
SET параметр_конфигурации FROM CURRENT
RESET параметр_конфигурации
RESET ALL
Описание
Команда ALTER PROCEDURE изменяет определение процедуры.
Чтобы использовать команду ALTER PROCEDURE, нужно быть владельцем
соответствующей процедуры. Чтобы изменить схему процедуры, необходимо помимо этого
иметь право CREATE в новой схеме. Для смены владельца нужно иметь возможность
выполнять SET ROLE для новой роли-владельца, и эта роль должна иметь право
CREATE в схеме процедуры. (Эти ограничения направлены на то, чтобы при смене
владельца не происходило ничего, что нельзя было бы сделать путем удаления и
повторного создания процедуры. Однако суперпользователь все равно может сменить
владельца любой процедуры.)
Параметры
имя
Имя существующей процедуры (может быть дополнено схемой). Если не указан список аргументов, имя должно быть уникальным в своей схеме.
режим_аргумента
Режим аргумента: IN (входной), OUT (выходной), INOUT (входной-выходной) или VARIADIC (переменный). Если этот параметр опущен, по умолчанию установлен режим IN.
имя_аргумента
Имя аргумента. Обратите внимание, что ALTER PROCEDURE фактически не обращает
никакого внимания на имена аргументов, поскольку для идентификации процедуры
используются только типы данных аргументов.
тип_аргумента
Тип(ы) данных аргументов процедуры (возможно, дополненный схемой), если таковые имеются. Подробную информацию о том, как нужная процедура находится с помощью типа(ов) данных аргументов, см. на справочной странице команды DROP PROCEDURE.
новое_имя
Новое имя процедуры.
новый_владелец
Новый владелец процедуры. Обратите внимание, что если процедура помечена как SECURITY DEFINER, в дальнейшем она будет выполняться от имени нового владельца.
новая_схема
Новая схема для процедуры.
имя_расширения
Эта форма помечает процедуру как зависящую от расширения или, если указано NO, как более не зависящую от этого расширения. Процедура, помеченная как зависящая от расширения, удаляется при удалении этого расширения, даже если не указано CASCADE. Процедура может зависеть от нескольких расширений и будет удалена при удалении любого из них.
[EXTERNAL] SECURITY INVOKER
[EXTERNAL] SECURITY DEFINER
Устанавливает, является ли процедура определяющей контекст безопасности. Ключевое слово EXTERNAL игнорируется для соответствия стандарту SQL. Дополнительную информацию об этой возможности см. на справочной странице команды CREATE PROCEDURE.
параметр_конфигурации
значение
Добавляет или изменяет установку параметра конфигурации, выполняемую при вызове
процедуры. Если значение равно DEFAULT или используется равнозначное
RESET, локальное значение для процедуры удаляется, и она выполняется со
значением, имеющимся в ее среде. Для удаления всех локальных значений для
процедуры укажите RESET ALL. SET FROM CURRENT сохраняет значение параметра,
действующее в момент выполнения команды ALTER PROCEDURE, в качестве значения,
применяемого при последующих вызовах процедуры.
Подробную информацию о допустимых именах и значениях параметров см. на
справочной странице команды SET и в главе Конфигурация сервера.
RESTRICT
Игнорируется для соответствия стандарту SQL.
Примеры
Переименование процедуры insert_data с двумя аргументами типа integer в insert_record:
ALTER PROCEDURE insert_data(integer, integer) RENAME TO insert_record;
Смена владельца процедуры insert_data с двумя аргументами типа integer на joe:
ALTER PROCEDURE insert_data(integer, integer) OWNER TO joe;
Изменение схемы процедуры insert_data с двумя аргументами типа integer на accounting:
ALTER PROCEDURE insert_data(integer, integer) SET SCHEMA accounting;
Обозначение процедуры insert_data(integer, integer) как зависящей от расширения myext:
ALTER PROCEDURE insert_data(integer, integer) DEPENDS ON EXTENSION myext;
Изменение пути поиска, который устанавливается для процедуры автоматически:
ALTER PROCEDURE check_password(text) SET search_path = admin, pg_temp;
Отмена автоматического определения search_path для процедуры:
ALTER PROCEDURE check_password(text) RESET search_path;
Теперь процедура будет выполняться с тем путем, который задан в момент вызова.
Совместимость
Эта команда частично схожа с командой ALTER PROCEDURE в стандарте SQL. Стандарт
позволяет изменять больше свойств процедуры, но не предоставляет возможности
переименовать процедуру, сделать ее определяющей контекст безопасности, связать
с процедурой значения параметров конфигурации или менять владельца, схему или тип
изменчивости процедуры. Кроме того, стандарт SQL требует наличия ключевого слова
RESTRICT, тогда как в QHB оно необязательно.
См. также
CREATE PROCEDURE, DROP PROCEDURE, ALTER FUNCTION, ALTER ROUTINE