加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql – PL / pgSQL – 从FUNCTION返回单个记录

发布时间:2020-12-13 15:49:57 所属栏目:百科 来源:网络整理
导读:我正在使用PL / pgSQL创建一个SP: CREATE OR REPLACE FUNCTION get_performance_achieve (p_month INT,p_year INT,p_uid INT) RETURNS TABLE (field1 INT,field2 INT) AS $datarows$DECLARE var_r record;BEGINfield1 :=0;field2 :=0;FOR var_r IN(select C
我正在使用PL / pgSQL创建一个SP:

CREATE OR REPLACE FUNCTION get_performance_achieve (p_month INT,p_year INT,p_uid INT) 
RETURNS TABLE (
field1 INT,field2 INT
) 
AS $datarows$
DECLARE var_r record;
BEGIN
field1 :=0;
field2 :=0;

FOR var_r IN(select COUNT(id) as counter from "TABLE_A" 
       )  
    LOOP
    field1 := (var_r.counter) ; 
    RETURN NEXT;
END LOOP;

FOR var_r IN(select COUNT(id) as counter from "TABLE_B" 
       )  
    LOOP
    field2 := (var_r.counter) ; 
    RETURN NEXT;
END LOOP;

END; 
$datarows$
LANGUAGE 'plpgsql';

当我执行SP时,它将返回2条记录:

> field1,0
> field1,field2

如何只返回field1,field2的单个记录

解决方法

在这种情况下,循环是多余的,使用简单的赋值:

CREATE OR REPLACE FUNCTION get_performance_achieve (p_month INT,p_uid INT) 
RETURNS TABLE (
    field1 INT,field2 INT
) 
AS $datarows$
BEGIN
    field1 := (select COUNT(id) as counter from "TABLE_A");
    field2 := (select COUNT(id) as counter from "TABLE_B");

    RETURN NEXT;
END; 
$datarows$
LANGUAGE 'plpgsql';

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读