CALL

CALL — вызвать процедуру

Синтаксис

CALL имя ( [ аргумент ] [, ...] )

Описание

CALL вызывает процедуру.

Если у процедуры есть выходные параметры, возвращается строка результата, содержащая значения этих параметров.

Параметры

имя

Имя процедуры (возможно, дополненное схемой).

аргумент

Выражение, определяющее аргумент для вызова процедуры.

В аргументе может передаваться имя параметра в записи имя => значение. Это работает так же, как и с обычными вызовами функций; за подробностями обратитесь к Разделу 4.3.

Аргументы должны задаваться для всех параметров процедуры, для которых не определены значения по умолчанию, включая параметры OUT. Однако аргументы, соответствующие параметрам OUT, не вычисляются, поэтому вместо них обычно часто просто пишут NULL. (Если передавать в параметрах OUT какие-то другие значения, возможны проблемы совместимости с будущими версиями PostgreSQL.)

Замечания

Чтобы вызывать процедуру, пользователь должен иметь право EXECUTE для неё.

Для вызова функции (не процедуры) следует использовать SELECT.

Если CALL выполняется в блоке транзакции, вызываемая процедура не может выполнять операторы управления транзакциями. Такие операторы допускаются, только если CALL выполняется в собственной транзакции.

Выходные параметры команд CALL в PL/pgSQL обрабатываются по-другому; см. Подраздел 41.6.3.

Примеры

CALL do_db_maintenance();

Совместимость

Команда CALL соответствует стандарту SQL, за исключением особенности обработки выходных параметров. Стандарт говорит, что для получения значений таких параметров нужно указывать переменные.

См. также

CREATE PROCEDURE