CALL

CALL — 调用一个过程

大纲

CALL name ( [ argument ] [, ...] )

简介

CALL执行一个过程。

如果过程有任何输出参数,则会返回一个结果行,返回这些参数的值。

参数

name

过程的名称(可以被方案限定)。

argument

过程调用的一个参数表达式。

参数可以包括参数名称,使用语法为 name => value。 这与普通函数调用的工作方式相同。 详细参考第 4.3 节

必须为所有缺少默认值的过程参数提供参数值,包括OUT参数。 然而,匹配OUT参数的参数不会被求值,因此通常为它们代入NULL。 (为OUT参数代入其他内容可能会导致与未来的 PostgreSQL版本的兼容问题。)

注解

用户必须有过程上的EXECUTE特权才能调用它。

要调用一个函数(不是过程),应使用SELECT

如果在事务块中执行CALL,那么被调用的过程不能执行事务控制语句。只有当CALL在其自身的事务中执行时,才允许过程执行事务控制语句。

PL/pgSQL 以不同的方式处理CALL中的输出参数。 详见第 43.6.3 节

示例

CALL do_db_maintenance();

兼容性

CALL符合SQL标准,除了输出参数的处理。 该标准规定,用户应该编写变量来接收输出参数的值。

另见

CREATE PROCEDURE