受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

CALL

CALL — 调用一个过程

Synopsis

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

描述

CALL执行一个过程。

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

参数

name

过程的名称(可以是模式限定的)。

argument

过程调用的参数表达式。

参数中可以包含参数名,使用语法 name => value。 这与普通函数调用中的工作方式相同;详见Section 4.3

对于所有没有默认值的过程参数,都必须提供参数,包括OUT参数。 不过,与OUT参数匹配的实参不会被求值, 因此通常只需写成NULL。 (如果为OUT参数写入其他内容, 可能会与未来的PostgreSQL版本产生兼容性问题。)

注解

用户必须拥有该过程的EXECUTE权限,才能调用它。

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

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

PL/pgSQLCALL命令中的输出参数采用不同的处理方式; 参见Section 41.6.3

示例

CALL do_db_maintenance();

兼容性

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

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。