文档首页 > > 开发指南> 存储过程> 基本语句> 返回语句

返回语句

分享
更新时间: 2019/06/24 GMT+08:00

语法

返回语句的语法请参见图1

图1 return_clause::=

对以上语法的解释如下:

用于将控制从存储过程返回给调用者。

示例

请参见调用语句的示例

存储函数的语法

RETURN NEXT和RETURN QUERY适用于函数,不适用存储过程。

在创建函数时需要指定返回值SETOF datatype。

return_next_clause::=

return_query_clause::=

对以上语法的解释如下:

当需要返回值是一个集合时,使用RETURN NEXT或者RETURN QUERY向结果集追加结果。然后继续执行函数的下一条语句。随着后续的RETURN NEXT或RETURN QUERY命令的执行,结果集中会有多个结果。函数执行完成后会一起返回。

RETURN NEXT 可以用用于标量和符合数据类型。

RETURN QUREY将执行一个查询,并将查询结果追加到函数的结果集中。RETURN QUERY 有一种变体 RETURN QUERY EXECUTE。 后面还可以增加动态查询。通过USING向查询插入参数。

存数函数的示例

postgres=# CREATE TABLE t1(a int);
postgres=# INSERT INTO t1 VALUES(1),(10);

--RETURN NEXT
CREATE OR REPLACE FUNCTION fun_for_return_next() RETURNS SETOF t1 AS $$
DECLARE
   r t1%ROWTYPE;
BEGIN
   FOR r IN select * from t1
   LOOP
      RETURN NEXT r;
   END LOOP;
   RETURN;
END;
$$ LANGUAGE PLPGSQL;
postgres=# call fun_for_return_next();
 a
---
 1
 10
(2 rows)

-- RETURN QUERY
CREATE OR REPLACE FUNCTION fun_for_return_query() RETURNS SETOF t1 AS $$
DECLARE
   r t1%ROWTYPE;
BEGIN
   RETURN QUERY select * from t1;
END;
$$
language plpgsql;
postgres=# call fun_for_return_next();
 a
---
 1
 10
(2 rows)
分享:

    相关文档

    相关产品

文档是否有解决您的问题?

提交成功!

非常感谢您的反馈,我们会继续努力做到更好!

反馈提交失败,请稍后再试!

*必选

请至少选择或填写一项反馈信息

字符长度不能超过200

提交反馈 取消

如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨

跳转到云社区