2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 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

提交更正

如果您在文档中发现任何不正确、与您在该特定功能上的使用经验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。