summaryrefslogtreecommitdiff
path: root/test/expected/plproxy_clustermap.out
blob: 83f3c67f5aa709d19be99fdb93dc06277f52ea1b (plain)
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
create or replace function plproxy.get_cluster_version(cluster_name text)
returns integer as $$
begin
    if cluster_name = 'testcluster' then
        return 6;
    elsif cluster_name = 'map0' then
        return 1;
    elsif cluster_name = 'map1' then
        return 1;
    elsif cluster_name = 'map2' then
        return 1;
    elsif cluster_name = 'map3' then
        return 1;
    end if;
    raise exception 'no such cluster: %', cluster_name;
end; $$ language plpgsql;
create or replace function plproxy.get_cluster_partitions(cluster_name text)
returns setof text as $$
begin
    if cluster_name = 'testcluster' then
        return next 'host=127.0.0.1 dbname=test_part0';
        return next 'host=127.0.0.1 dbname=test_part1';
        return next 'host=127.0.0.1 dbname=test_part2';
        return next 'host=127.0.0.1 dbname=test_part3';
    elsif cluster_name = 'map0' then
        return next 'host=127.0.0.1 dbname=test_part0';
    elsif cluster_name = 'map1' then
        return next 'host=127.0.0.1 dbname=test_part1';
    elsif cluster_name = 'map2' then
        return next 'host=127.0.0.1 dbname=test_part2';
    elsif cluster_name = 'map3' then
        return next 'host=127.0.0.1 dbname=test_part3';
    else
        raise exception 'no such cluster: %', cluster_name;
    end if;
    return;
end; $$ language plpgsql;
create function map_cluster(part integer) returns text as $$
begin
    return 'map' || part;
end;
$$ language plpgsql;
create function test_clustermap(part integer) returns setof text as $$
    cluster map_cluster(part);
    run on 0;
    select current_database();
$$ language plproxy;
select * from test_clustermap(0);
 test_clustermap 
-----------------
 test_part0
(1 row)

select * from test_clustermap(1);
 test_clustermap 
-----------------
 test_part1
(1 row)

select * from test_clustermap(2);
 test_clustermap 
-----------------
 test_part2
(1 row)

select * from test_clustermap(3);
 test_clustermap 
-----------------
 test_part3
(1 row)