blob: 4210dd417f6a01d578d52cbeb0a114bf3fd49405 [file] [log] [blame]
-- Test Mark/Restore in Material Node
create table spilltest1 (a integer);
create table spilltest2 (a integer);
insert into spilltest1 select a from generate_series(1,400000) a;
insert into spilltest2 select a from generate_series(1,400000) a;
set enable_hashagg=off;
set enable_mergejoin=on;
set enable_hashjoin=off;
set enable_nestloop=off;
set statement_mem=10000;
create temporary table spilltestresult1 as
select t1.a as t1a, t2.a as t2a
from (select a from spilltest1 group by a) t1,
(select a from spilltest2 group by a) t2
where t1.a = t2.a;
-- check that the result looks sane
select count(*), sum(t1a), sum(t2a), sum(t1a - t2a) from spilltestresult1;
-- Test Hash Aggregation when the work mem is too small for the hash table
create table spilltest (a integer, b integer);
insert into spilltest select a, a%25 from generate_series(1,8000) a;
analyze spilltest;
set enable_hashagg=on;
set enable_groupagg=off;
set statement_mem=10000;
select b,count(*) from spilltest group by b;
select b,count(*) from spilltest group by b;
-- Test Hash Join when the work mem is too small for the hash table
drop table if exists spilltest;
create table spilltest (a integer, b integer);
insert into spilltest select a, a%25 from generate_series(1,800000) a;
analyze spilltest; -- We have to do an analyze to force a hash join
set enable_mergejoin=off;
set enable_nestloop=off;
set enable_hashjoin=on;
set statement_mem=10000;
create temporary table spilltestresult2 as
select t1.a as t1a, t1.b as t1b, t2.a as t2a, t2.b as t2b from spilltest t1, spilltest t2 where t1.a = t2.a;
-- check that the result looks sane
select count(*), sum(t1a), sum(t2a), sum(t2a), sum(t2b), sum(t1a * t1b) from spilltestresult2;
drop table spilltest1;
drop table spilltest2;
drop table spilltest;