File: plproxy_dynamic_record.sql

package info (click to toggle)
postgresql-plproxy 2.11.0-12
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 564 kB
  • sloc: ansic: 3,476; sql: 1,136; lex: 340; yacc: 171; makefile: 93; sh: 18; awk: 14
file content (43 lines) | stat: -rw-r--r-- 1,242 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
-- dynamic query support testing
create or replace function dynamic_query(q text)
returns setof record as $x$
    cluster 'map0';
    run on all;
$x$ language plproxy;

\c test_part0
create or replace function dynamic_query(q text)
returns setof record as $x$
declare
    ret record;
begin
    for ret in execute q loop
        return next ret;
    end loop;
    return;
end;
$x$ language plpgsql;
create table dynamic_query_test (
    id integer,
    username text,
		other	text
);
insert into dynamic_query_test values ( 1, 'user1', 'blah');
insert into dynamic_query_test values ( 2, 'user2', 'foo');

\c regression
select * from dynamic_query('select * from dynamic_query_test') as (id integer, username text, other text);
select * from dynamic_query('select id, username from dynamic_query_test') as foo(id integer, username text);
-- invalid usage
select * from dynamic_query('select count(1) from pg_class');
select dynamic_query('select count(1) from pg_class');

-- test errors
create or replace function dynamic_query_select()
returns setof record as $x$
    cluster 'map0';
    run on all;
    select id, username from dynamic_query_test;
$x$ language plproxy;
select * from dynamic_query_select() as (id integer, username text);