Commit 76df765e authored by Jeff Davis's avatar Jeff Davis

Reduce test time for disk-based Hash Aggregation.

Discussion: https://postgr.es/m/23196.1584943506@sss.pgh.pa.us
parent 67e0adfb
...@@ -2453,22 +2453,22 @@ set work_mem='64kB'; ...@@ -2453,22 +2453,22 @@ set work_mem='64kB';
set enable_hashagg = false; set enable_hashagg = false;
set jit_above_cost = 0; set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
QUERY PLAN QUERY PLAN
------------------------------------------------ ------------------------------------------------
GroupAggregate GroupAggregate
Group Key: ((g % 100000)) Group Key: ((g % 10000))
-> Sort -> Sort
Sort Key: ((g % 100000)) Sort Key: ((g % 10000))
-> Function Scan on generate_series g -> Function Scan on generate_series g
(5 rows) (5 rows)
create table agg_group_1 as create table agg_group_1 as
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
create table agg_group_2 as create table agg_group_2 as
select * from select * from
(values (100), (300), (500)) as r(a), (values (100), (300), (500)) as r(a),
...@@ -2493,20 +2493,20 @@ set enable_hashagg = true; ...@@ -2493,20 +2493,20 @@ set enable_hashagg = true;
set enable_sort = false; set enable_sort = false;
set jit_above_cost = 0; set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
QUERY PLAN QUERY PLAN
------------------------------------------ ------------------------------------------
HashAggregate HashAggregate
Group Key: (g % 100000) Group Key: (g % 10000)
-> Function Scan on generate_series g -> Function Scan on generate_series g
(3 rows) (3 rows)
create table agg_hash_1 as create table agg_hash_1 as
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
create table agg_hash_2 as create table agg_hash_2 as
select * from select * from
(values (100), (300), (500)) as r(a), (values (100), (300), (500)) as r(a),
......
...@@ -1644,10 +1644,10 @@ SET work_mem='64kB'; ...@@ -1644,10 +1644,10 @@ SET work_mem='64kB';
set enable_hashagg = false; set enable_hashagg = false;
set jit_above_cost = 0; set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
QUERY PLAN QUERY PLAN
--------------------------------------------------------------- ---------------------------------------------------------------
GroupAggregate GroupAggregate
...@@ -1667,31 +1667,18 @@ group by cube (g1000,g100,g10); ...@@ -1667,31 +1667,18 @@ group by cube (g1000,g100,g10);
(14 rows) (14 rows)
create table gs_group_1 as create table gs_group_1 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
set jit_above_cost to default;
create table gs_group_2 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g/20 as g1000, g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by cube (g1000,g100,g10);
create table gs_group_3 as
select g100, g10, array_agg(g) as a, count(*) as c, max(g::text) as m from
(select g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by grouping sets (g100,g10);
-- Produce results with hash aggregation. -- Produce results with hash aggregation.
set enable_hashagg = true; set enable_hashagg = true;
set enable_sort = false; set enable_sort = false;
set work_mem='64kB';
set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
QUERY PLAN QUERY PLAN
--------------------------------------------------- ---------------------------------------------------
MixedAggregate MixedAggregate
...@@ -1707,52 +1694,21 @@ group by cube (g1000,g100,g10); ...@@ -1707,52 +1694,21 @@ group by cube (g1000,g100,g10);
(10 rows) (10 rows)
create table gs_hash_1 as create table gs_hash_1 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
set jit_above_cost to default;
create table gs_hash_2 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g/20 as g1000, g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by cube (g1000,g100,g10);
create table gs_hash_3 as
select g100, g10, array_agg(g) as a, count(*) as c, max(g::text) as m from
(select g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by grouping sets (g100,g10);
set enable_sort = true; set enable_sort = true;
set work_mem to default; set work_mem to default;
-- Compare results -- Compare results
(select * from gs_hash_1 except select * from gs_group_1) (select * from gs_hash_1 except select * from gs_group_1)
union all union all
(select * from gs_group_1 except select * from gs_hash_1); (select * from gs_group_1 except select * from gs_hash_1);
g1000 | g100 | g10 | sum | count | max g100 | g10 | sum | count | max
-------+------+-----+-----+-------+----- ------+-----+-----+-------+-----
(0 rows)
(select * from gs_hash_2 except select * from gs_group_2)
union all
(select * from gs_group_2 except select * from gs_hash_2);
g1000 | g100 | g10 | sum | count | max
-------+------+-----+-----+-------+-----
(0 rows)
(select g100,g10,unnest(a),c,m from gs_hash_3 except
select g100,g10,unnest(a),c,m from gs_group_3)
union all
(select g100,g10,unnest(a),c,m from gs_group_3 except
select g100,g10,unnest(a),c,m from gs_hash_3);
g100 | g10 | unnest | c | m
------+-----+--------+---+---
(0 rows) (0 rows)
drop table gs_group_1; drop table gs_group_1;
drop table gs_group_2;
drop table gs_group_3;
drop table gs_hash_1; drop table gs_hash_1;
drop table gs_hash_2;
drop table gs_hash_3;
SET enable_groupingsets_hash_disk TO DEFAULT; SET enable_groupingsets_hash_disk TO DEFAULT;
-- end -- end
...@@ -1066,14 +1066,14 @@ set enable_hashagg = false; ...@@ -1066,14 +1066,14 @@ set enable_hashagg = false;
set jit_above_cost = 0; set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
create table agg_group_1 as create table agg_group_1 as
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
create table agg_group_2 as create table agg_group_2 as
select * from select * from
...@@ -1106,14 +1106,14 @@ set enable_sort = false; ...@@ -1106,14 +1106,14 @@ set enable_sort = false;
set jit_above_cost = 0; set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
create table agg_hash_1 as create table agg_hash_1 as
select g%100000 as c1, sum(g::numeric) as c2, count(*) as c3 select g%10000 as c1, sum(g::numeric) as c2, count(*) as c3
from generate_series(0, 199999) g from generate_series(0, 19999) g
group by g%100000; group by g%10000;
create table agg_hash_2 as create table agg_hash_2 as
select * from select * from
......
...@@ -453,68 +453,37 @@ SET work_mem='64kB'; ...@@ -453,68 +453,37 @@ SET work_mem='64kB';
-- Produce results with sorting. -- Produce results with sorting.
set enable_hashagg = false; set enable_hashagg = false;
set jit_above_cost = 0; set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
create table gs_group_1 as create table gs_group_1 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
set jit_above_cost to default;
create table gs_group_2 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g/20 as g1000, g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by cube (g1000,g100,g10);
create table gs_group_3 as
select g100, g10, array_agg(g) as a, count(*) as c, max(g::text) as m from
(select g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by grouping sets (g100,g10);
-- Produce results with hash aggregation. -- Produce results with hash aggregation.
set enable_hashagg = true; set enable_hashagg = true;
set enable_sort = false; set enable_sort = false;
set work_mem='64kB';
set jit_above_cost = 0;
explain (costs off) explain (costs off)
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
create table gs_hash_1 as create table gs_hash_1 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from select g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g%1000 as g1000, g%100 as g100, g%10 as g10, g (select g%1000 as g1000, g%100 as g100, g%10 as g10, g
from generate_series(0,199999) g) s from generate_series(0,1999) g) s
group by cube (g1000,g100,g10); group by cube (g1000, g100,g10);
set jit_above_cost to default;
create table gs_hash_2 as
select g1000, g100, g10, sum(g::numeric), count(*), max(g::text) from
(select g/20 as g1000, g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by cube (g1000,g100,g10);
create table gs_hash_3 as
select g100, g10, array_agg(g) as a, count(*) as c, max(g::text) as m from
(select g/200 as g100, g/2000 as g10, g
from generate_series(0,19999) g) s
group by grouping sets (g100,g10);
set enable_sort = true; set enable_sort = true;
set work_mem to default; set work_mem to default;
...@@ -525,22 +494,8 @@ set work_mem to default; ...@@ -525,22 +494,8 @@ set work_mem to default;
union all union all
(select * from gs_group_1 except select * from gs_hash_1); (select * from gs_group_1 except select * from gs_hash_1);
(select * from gs_hash_2 except select * from gs_group_2)
union all
(select * from gs_group_2 except select * from gs_hash_2);
(select g100,g10,unnest(a),c,m from gs_hash_3 except
select g100,g10,unnest(a),c,m from gs_group_3)
union all
(select g100,g10,unnest(a),c,m from gs_group_3 except
select g100,g10,unnest(a),c,m from gs_hash_3);
drop table gs_group_1; drop table gs_group_1;
drop table gs_group_2;
drop table gs_group_3;
drop table gs_hash_1; drop table gs_hash_1;
drop table gs_hash_2;
drop table gs_hash_3;
SET enable_groupingsets_hash_disk TO DEFAULT; SET enable_groupingsets_hash_disk TO DEFAULT;
......
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