CALL
CALL — invoke a procedure
Synopsis
CALLname( [argument] [, ...] )
Description
CALL executes a procedure.
If the procedure has any output parameters, then a result row will be returned, containing the values of those parameters.
Parameters
nameThe name (optionally schema-qualified) of the procedure.
argumentAn argument expression for the procedure call.
Arguments can include parameter names, using the syntax
. This works the same as in ordinary function calls; seeSection 4.3 for details.name=>valueArguments must be supplied for all procedure parameters that lack defaults, including
OUTparameters. However, arguments matchingOUTparameters are not evaluated, so it's customary to just writeNULLfor them. (Writing something else for anOUTparameter might cause compatibility problems with futurePostgreSQL versions.)
Notes
The user must haveEXECUTE privilege on the procedure in order to be allowed to invoke it.
To call a function (not a procedure), useSELECT instead.
IfCALL is executed in a transaction block, then the called procedure cannot execute transaction control statements. Transaction control statements are only allowed ifCALL is executed in its own transaction.
PL/pgSQL handles output parameters inCALL commands differently; seeSection 42.6.3.
Examples
CALL do_db_maintenance();
Compatibility
CALL conforms to the SQL standard, except for the handling of output parameters. The standard says that users should write variables to receive the values of output parameters.