【原创】PostgreSQL 返回多个结果集

本文对比了MySQL和PostgreSQL在处理存储过程返回多个结果集的功能,指出MySQL支持一次性返回多个结果集,而PostgreSQL则需通过游标或其他方式实现。通过示例展示了如何在PostgreSQL中使用游标实现类似功能,并讨论了当结果集为单行数据时,使用OUT参数的优化方案。文章最后提供了关键信息总结和相关技术领域关键词。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySQL的存储过程 可以很方便的一次性的返回多个结果集, 但是POSTGRESQL目前不提供这样的功能。

一个直译的方法就是用游标来做,不过也可以把结果集放到数组里面或者一个大的临时表或者是XML等的格式来输出。


比如在MySQL里面可以这样简单的写一个存储过程。


delimiter ||
create procedure sp_get_multiple_set1()
begin
  select * from j1 limit 20;
  select * from tmp_2 limit 20;
end;
||
delimiter ;
执行下会得到两个结果集。
t_girl--call sp_get_multiple_set1();
+------+------+
| id   | str1 |
+------+------+
|    1 | love |
|    2 | hate |
+------+------+
2 rows in set (0.00 sec)
+------+---------------+
| id   | register_date |
+------+---------------+
|    1 | 2014-01-18    |
|    2 | 2014-01-03    |
|    3 | 2014-01-16    |
+------+---------------+
3 rows in set (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
t_girl--



在PostgreSQL环境下,来看下下面的函数代码,只能用游标来实现,而且还不能在函数里面返回。


create or replace function sp_get_multiple_set1(
IN f_id int,
refcursor,
refcursor
) returns setof refcursor
as
$ytt$
declare r1 alias for $2;
               r2 alias for $3;
begin
   open  r1 for select * from j1 where id =f_id;
   return next r1;
   open r2 for select * from tmp_2 where id = f_id;
   return next r2;
end;
$ytt$ language plpgsql;


接下来,在一个事务里面来获取对应的游标结果集。


t_girl=# begin;
BEGIN
t_girl=# select * from sp_get_multiple_set1(1,'a'::refcursor,'b'::refcursor);
 sp_get_multiple_set1
----------------------
 a
 b
(2 rows)
t_girl=# fetch all from a;
 id | str1
----+------
  1 | love
(1 row)
t_girl=# fetch all from b;
 id | register_date
----+---------------
  1 | 2013-01-20
(1 row)
t_girl=# close a;
CLOSE CURSOR
t_girl=# close b;
CLOSE CURSOR
t_girl=# commit;
COMMIT
t_girl=#


如果是是多个结果集,但是每个结果集里面只有一行数据的话,也可以用OUT参数来实现。


create or replace function sp_get_single_set2(
f_id int,
IN refcursor,
IN refcursor,
OUT r3 ytt_j1,
OUT r4 ytt_tmp_2
) returns  record
as
$ytt$
declare r1 alias for $2;
              r2 alias for $3;
begin
   open  r1 for select * from j1 where id =f_id;
   open r2 for select * from tmp_2 where id = f_id;
   loop
      fetch r1 into r3;
      fetch r2 into r4;
      exit when not found;
      return;
   end loop;
   close r1;
   close r2;
end;
$ytt$ language plpgsql;
t_girl=# select * from sp_get_multiple_set2(1,'a'::refcursor,'b'::refcursor);
    r3    |       r4      
----------+----------------
 (1,love) | (1,2013-01-20)
(1 row)
t_girl=#

如果返回的多个结果集的字段和类型都一致的话,那就跟单个结果集一样了。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值