CALL — 调用一个过程
CALLname( [argument] [, ...] )
CALL执行一个过程。
如果该过程有任何输出参数,则会返回一行结果,其中包含这些参数的值。
name过程的名称(可以是模式限定的)。
argument过程调用的参数表达式。
参数中可以包含参数名,使用语法 。 这与普通函数调用中的工作方式相同;详见Section 4.3。name => value
对于所有没有默认值的过程参数,都必须提供参数,包括OUT参数。 不过,与OUT参数匹配的实参不会被求值, 因此通常只需写成NULL。 (如果为OUT参数写入其他内容, 可能会与未来的PostgreSQL版本产生兼容性问题。)
用户必须拥有该过程的EXECUTE权限,才能调用它。
若要调用函数(而不是过程),请改用SELECT。
如果在事务块中执行CALL,则被调用的过程不能执行事务控制语句。 只有当CALL作为独立事务执行时,才允许使用事务控制语句。
PL/pgSQL对CALL命令中的输出参数采用不同的处理方式; 参见Section 41.6.3。
CALL do_db_maintenance();
CALL符合 SQL 标准,但对输出参数的处理除外。 标准规定用户应写变量来接收输出参数的值。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。