CALL — 调用一个过程
CALLname
( [argument
] [, ...] )
CALL
执行一个过程。
如果过程有任何输出参数,则会返回一个结果行,返回这些参数的值。
name
过程的名称(可以被方案限定)。
argument
过程调用的一个参数表达式。
参数可以包括参数名称,使用语法为
。
这与普通函数调用的工作方式相同。
详细参考第 4.3 节。
name
=> value
必须为所有缺少默认值的过程参数提供参数值,包括OUT
参数。
然而,匹配OUT
参数的参数不会被求值,因此通常为它们代入NULL
。
(为OUT
参数代入其他内容可能会导致与未来的
PostgreSQL版本的兼容问题。)
用户必须有过程上的EXECUTE
特权才能调用它。
要调用一个函数(不是过程),应使用SELECT
。
如果在事务块中执行CALL
,那么被调用的过程不能执行事务控制语句。只有当CALL
在其自身的事务中执行时,才允许过程执行事务控制语句。
PL/pgSQL 以不同的方式处理CALL
中的输出参数。
详见第 43.6.3 节。
CALL do_db_maintenance();
CALL
符合SQL标准,除了输出参数的处理。
该标准规定,用户应该编写变量来接收输出参数的值。