|
|
|
@ -109,7 +109,7 @@ begin |
|
|
|
|
for group_key in select unnest(array['Full-sort Groups', 'Presorted Groups']::text[]) t loop |
|
|
|
|
for space_key in select unnest(array['Sort Space Memory', 'Sort Space Disk']::text[]) t loop |
|
|
|
|
node := jsonb_set(node, array[group_key, space_key, 'Average Sort Space Used'], '"NN"', false); |
|
|
|
|
node := jsonb_set(node, array[group_key, space_key, 'Maximum Sort Space Used'], '"NN"', false); |
|
|
|
|
node := jsonb_set(node, array[group_key, space_key, 'Peak Sort Space Used'], '"NN"', false); |
|
|
|
|
end loop; |
|
|
|
|
end loop; |
|
|
|
|
nodes := nodes || node; |
|
|
|
@ -131,7 +131,7 @@ begin |
|
|
|
|
for group_key in select unnest(array['Full-sort Groups', 'Presorted Groups']::text[]) t loop |
|
|
|
|
group_stats := node->group_key; |
|
|
|
|
for space_key in select unnest(array['Sort Space Memory', 'Sort Space Disk']::text[]) t loop |
|
|
|
|
if (group_stats->space_key->'Maximum Sort Space Used')::bigint < (group_stats->space_key->'Maximum Sort Space Used')::bigint then |
|
|
|
|
if (group_stats->space_key->'Peak Sort Space Used')::bigint < (group_stats->space_key->'Peak Sort Space Used')::bigint then |
|
|
|
|
raise exception '% has invalid max space < average space', group_key; |
|
|
|
|
end if; |
|
|
|
|
end loop; |
|
|
|
@ -546,7 +546,7 @@ select explain_analyze_without_memory('select * from (select * from t order by a |
|
|
|
|
|
|
|
|
|
select jsonb_pretty(explain_analyze_inc_sort_nodes_without_memory('select * from (select * from t order by a) s order by a, b limit 55')); |
|
|
|
|
jsonb_pretty |
|
|
|
|
-------------------------------------------------- |
|
|
|
|
------------------------------------------------- |
|
|
|
|
[ + |
|
|
|
|
{ + |
|
|
|
|
"Sort Key": [ + |
|
|
|
@ -567,8 +567,8 @@ select jsonb_pretty(explain_analyze_inc_sort_nodes_without_memory('select * from |
|
|
|
|
"quicksort" + |
|
|
|
|
], + |
|
|
|
|
"Sort Space Memory": { + |
|
|
|
|
"Average Sort Space Used": "NN",+ |
|
|
|
|
"Maximum Sort Space Used": "NN" + |
|
|
|
|
"Peak Sort Space Used": "NN", + |
|
|
|
|
"Average Sort Space Used": "NN"+ |
|
|
|
|
} + |
|
|
|
|
}, + |
|
|
|
|
"Parent Relationship": "Outer" + |
|
|
|
@ -720,7 +720,7 @@ select explain_analyze_without_memory('select * from (select * from t order by a |
|
|
|
|
|
|
|
|
|
select jsonb_pretty(explain_analyze_inc_sort_nodes_without_memory('select * from (select * from t order by a) s order by a, b limit 70')); |
|
|
|
|
jsonb_pretty |
|
|
|
|
-------------------------------------------------- |
|
|
|
|
------------------------------------------------- |
|
|
|
|
[ + |
|
|
|
|
{ + |
|
|
|
|
"Sort Key": [ + |
|
|
|
@ -740,8 +740,8 @@ select jsonb_pretty(explain_analyze_inc_sort_nodes_without_memory('select * from |
|
|
|
|
"quicksort" + |
|
|
|
|
], + |
|
|
|
|
"Sort Space Memory": { + |
|
|
|
|
"Average Sort Space Used": "NN",+ |
|
|
|
|
"Maximum Sort Space Used": "NN" + |
|
|
|
|
"Peak Sort Space Used": "NN", + |
|
|
|
|
"Average Sort Space Used": "NN"+ |
|
|
|
|
} + |
|
|
|
|
}, + |
|
|
|
|
"Presorted Groups": { + |
|
|
|
@ -750,8 +750,8 @@ select jsonb_pretty(explain_analyze_inc_sort_nodes_without_memory('select * from |
|
|
|
|
"quicksort" + |
|
|
|
|
], + |
|
|
|
|
"Sort Space Memory": { + |
|
|
|
|
"Average Sort Space Used": "NN",+ |
|
|
|
|
"Maximum Sort Space Used": "NN" + |
|
|
|
|
"Peak Sort Space Used": "NN", + |
|
|
|
|
"Average Sort Space Used": "NN"+ |
|
|
|
|
} + |
|
|
|
|
}, + |
|
|
|
|
"Parent Relationship": "Outer" + |
|
|
|
|