MSSQL のように、Postgres 関数から複数の結果セットを返すことは可能ですか?
CREATE PROCEDURE test
AS
SELECT * FROM first_table
SELECT * FROM second_table
MSSQL のように、Postgres 関数から複数の結果セットを返すことは可能ですか?
CREATE PROCEDURE test
AS
SELECT * FROM first_table
SELECT * FROM second_table
PostgreSQL 8.3 以降、より簡単な方法があります。
CREATE FUNCTION test()
RETURNS SETOF first_table AS
$func$
BEGIN
RETURN QUERY
SELECT * FROM first_table;
RETURN QUERY
SELECT * FROM second_table; -- has to return same rowtype as first_table!
END
$func$ LANGUAGE plpgsql;
電話:
SELECT * FROM test();
両方の結果セットが、関数から返された 1 つのセットに追加されます。のマニュアルを
参照してください。RETURN QUERY
CREATE OR REPLACE FUNCTION "pr_GetCustomersAndOrders"()
RETURNS SETOF refcursor AS
$BODY$DECLARE
customerRC refcursor;
orderRC refcursor;
BEGIN
open customerRC FOR
SELECT * FROM customers;
RETURN NEXT customerRC;
open orderRC FOR
SELECT * FROM orders;
RETURN NEXT orderRC;
RETURN;
END;$BODY$
LANGUAGE 'plpgsql' VOLATILE;
ALTER FUNCTION "pr_GetCustomersAndOrders"() OWNER TO postgres;
私はrefcursorsを使用しています:)
first_table
と同じレイアウトの場合second_table
は、そのまま使用することもできます
SELECT * FROM first_table WHERE ...
UNION ALL
SELECT * FROM second_table WHERE ...
UNION ALL
[編集:よりも高速であることを指摘してくれたコメント投稿者 (名前はおそらく「null」ではない :) ) に感謝しますUNION
。
はい。
例:
test=# create function x () returns setof integer language plpgsql as $$ begin return next 1; return next 2; end $$;
CREATE FUNCTION
test=# select * from x();
x
---
1
2
(2 rows)
もちろん、返される型に既存のテーブル/ビューまたはカスタム型を使用できます。
言語 SQL を使用した例:
test=# create table customer (name varchar, birth_date date);
CREATE TABLE
test=# create function y () returns setof customer language sql as $$
select * from customer
union all
select * from customer
$$;
CREATE FUNCTION
test=# insert into customer values ('joe', now()::date);
INSERT 0 1
test=# insert into customer values ('jill', now()::date);
INSERT 0 1
test=# select * from y();
name | birth_date
------+------------
joe | 2009-04-16
jill | 2009-04-16
joe | 2009-04-16
jill | 2009-04-16
(4 rows)