Redrock Postgres 搜索 英文
版本: 11 / 12 / 13 / 14 / 15 / 16 / 17

CALL

CALL —— 调用存储过程

语法

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

说明

CALL 执行存储过程。

如果存储过程具有任何输出参数,则会返回包含这些参数值的结果行。

参数

name

存储过程的名称(可选的模式限定)。

argument

存储过程调用的参数表达式。

参数可以使用 name => value 语法包含参数名称。这与普通函数调用中的工作方式相同;有关详细信息,请参见 第 4.3 节

必须为所有缺少默认值的存储过程参数(包括 OUT 参数)提供参数。但是,与 OUT 参数匹配的参数不会被评估,因此通常只为它们编写 NULL。 (为 OUT 参数编写其他内容可能会导致与未来 PostgreSQL 版本的兼容性问题。)

注释

用户必须具有要调用的存储过程上的 EXECUTE 特权,才能被允许调用它。

要调用函数(不是存储过程),请改用 SELECT

如果在事务块中执行 CALL,则被调用的存储过程不能执行事务控制语句。仅当在自己的事务中执行 CALL 时,才允许事务控制语句。

PL/pgSQLCALL 命令中以不同的方式处理输出参数;请参见 第 41.6.3 节

示例

CALL do_db_maintenance();

兼容性

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

另请参阅

CREATE PROCEDURE