2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:devel
不支持的版本:11

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

提交更正

如果您在文档中看到任何不正确的内容,与您对特定功能的体验不符,或者需要进一步澄清,请使用此表单 报告文档问题。