CALL — 调用过程
CALLname( [argument] [, ...] )
CALL 执行一个过程。
如果该过程有任何输出参数,那么将返回一个结果行,其中包含这些参数的值。
name过程的名称(可选地以架构限定)。
argument过程调用的参数表达式。
参数可以使用参数名称,语法为 。这与普通函数调用中的工作方式相同;有关详细信息,请参见 第 4.3 节。name => value
必须为所有缺少默认值的过程参数(包括 OUT 参数)提供参数。但是,与 OUT 参数匹配的参数不会被求值,因此通常为它们编写 NULL。(为 OUT 参数编写其他内容可能会导致与未来 PostgreSQL 版本的兼容性问题。)
用户必须具有过程的 EXECUTE 权限才能被允许调用该过程。
要调用函数(而不是过程),请改用 SELECT。
如果在事务块中执行 CALL,那么被调用的过程不能执行事务控制语句。只有在 CALL 在其自身事务中执行时才允许事务控制语句。
PL/pgSQL 在 CALL 命令中以不同的方式处理输出参数;请参见 第 43.6.3 节。
CALL do_db_maintenance();
CALL 符合 SQL 标准,但输出参数的处理除外。该标准规定用户应编写变量以接收输出参数的值。
如果您在文档中发现任何不正确、与您对特定功能的体验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。