支持的版本:当前17)/ 16 / 15 / 14 / 13
开发版本:devel
不支持的版本:12 / 11

CALL

CALL — 调用一个过程

概要

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

描述

CALL 执行一个过程。

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

参数

name

过程的名称(可选地使用模式限定)。

argument

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

参数可以包含参数名,使用语法 name => value。这和普通的函数调用一样;请参考第 4.3 节了解详细信息。

必须为所有没有默认值的过程参数提供参数,包括 OUT 参数。但是,与 OUT 参数匹配的参数不会被求值,因此习惯上为它们只写 NULL。(为 OUT 参数写入其他内容可能会导致与未来 PostgreSQL 版本不兼容的问题。)

注意

用户必须对该过程拥有 EXECUTE 权限才能被允许调用它。

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

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

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

示例

CALL do_db_maintenance();

兼容性

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

另请参阅

CREATE PROCEDURE

提交更正

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