Commit 8c78f8e6 authored by Bruce Momjian's avatar Bruce Momjian

Add PL/PgSQL FOUND and GET DIAGNOSTICS support for RETURN QUERY

statement

Pavel Stehule
parent 78cbd498
<!-- $PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.137 2009/02/04 21:30:41 alvherre Exp $ --> <!-- $PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.138 2009/02/05 15:25:49 momjian Exp $ -->
<chapter id="plpgsql"> <chapter id="plpgsql">
<title><application>PL/pgSQL</application> - <acronym>SQL</acronym> Procedural Language</title> <title><application>PL/pgSQL</application> - <acronym>SQL</acronym> Procedural Language</title>
...@@ -1356,6 +1356,14 @@ GET DIAGNOSTICS integer_var = ROW_COUNT; ...@@ -1356,6 +1356,14 @@ GET DIAGNOSTICS integer_var = ROW_COUNT;
execution of other statements within the loop body. execution of other statements within the loop body.
</para> </para>
</listitem> </listitem>
<listitem>
<para>
A <command>RETURN QUERY</command> and <command>RETURN QUERY
EXECUTE</command> statements set <literal>FOUND</literal>
true if the query returns at least one row, false if no row
is returned.
</para>
</listitem>
</itemizedlist> </itemizedlist>
<literal>FOUND</literal> is a local variable within each <literal>FOUND</literal> is a local variable within each
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/pl/plpgsql/src/pl_exec.c,v 1.231 2009/01/21 11:13:14 heikki Exp $ * $PostgreSQL: pgsql/src/pl/plpgsql/src/pl_exec.c,v 1.232 2009/02/05 15:25:49 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -2286,6 +2286,7 @@ exec_stmt_return_query(PLpgSQL_execstate *estate, ...@@ -2286,6 +2286,7 @@ exec_stmt_return_query(PLpgSQL_execstate *estate,
PLpgSQL_stmt_return_query *stmt) PLpgSQL_stmt_return_query *stmt)
{ {
Portal portal; Portal portal;
uint32 processed = 0;
if (!estate->retisset) if (!estate->retisset)
ereport(ERROR, ereport(ERROR,
...@@ -2327,6 +2328,7 @@ exec_stmt_return_query(PLpgSQL_execstate *estate, ...@@ -2327,6 +2328,7 @@ exec_stmt_return_query(PLpgSQL_execstate *estate,
HeapTuple tuple = SPI_tuptable->vals[i]; HeapTuple tuple = SPI_tuptable->vals[i];
tuplestore_puttuple(estate->tuple_store, tuple); tuplestore_puttuple(estate->tuple_store, tuple);
processed++;
} }
MemoryContextSwitchTo(old_cxt); MemoryContextSwitchTo(old_cxt);
...@@ -2336,6 +2338,9 @@ exec_stmt_return_query(PLpgSQL_execstate *estate, ...@@ -2336,6 +2338,9 @@ exec_stmt_return_query(PLpgSQL_execstate *estate,
SPI_freetuptable(SPI_tuptable); SPI_freetuptable(SPI_tuptable);
SPI_cursor_close(portal); SPI_cursor_close(portal);
estate->eval_processed = processed;
exec_set_found(estate, processed != 0);
return PLPGSQL_RC_OK; return PLPGSQL_RC_OK;
} }
......
...@@ -3666,3 +3666,35 @@ select * from tftest(10); ...@@ -3666,3 +3666,35 @@ select * from tftest(10);
(2 rows) (2 rows)
drop function tftest(int); drop function tftest(int);
create or replace function rttest()
returns setof int as $$
declare rc int;
begin
return query values(10),(20);
get diagnostics rc = row_count;
raise notice '% %', found, rc;
return query select * from (values(10),(20)) f(a) where false;
get diagnostics rc = row_count;
raise notice '% %', found, rc;
return query execute 'values(10),(20)';
get diagnostics rc = row_count;
raise notice '% %', found, rc;
return query execute 'select * from (values(10),(20)) f(a) where false';
get diagnostics rc = row_count;
raise notice '% %', found, rc;
end;
$$ language plpgsql;
select * from rttest();
NOTICE: t 2
NOTICE: f 0
NOTICE: t 2
NOTICE: f 0
rttest
--------
10
20
10
20
(4 rows)
drop function rttest();
...@@ -2948,3 +2948,27 @@ $$ language plpgsql immutable strict; ...@@ -2948,3 +2948,27 @@ $$ language plpgsql immutable strict;
select * from tftest(10); select * from tftest(10);
drop function tftest(int); drop function tftest(int);
create or replace function rttest()
returns setof int as $$
declare rc int;
begin
return query values(10),(20);
get diagnostics rc = row_count;
raise notice '% %', found, rc;
return query select * from (values(10),(20)) f(a) where false;
get diagnostics rc = row_count;
raise notice '% %', found, rc;
return query execute 'values(10),(20)';
get diagnostics rc = row_count;
raise notice '% %', found, rc;
return query execute 'select * from (values(10),(20)) f(a) where false';
get diagnostics rc = row_count;
raise notice '% %', found, rc;
end;
$$ language plpgsql;
select * from rttest();
drop function rttest();
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment