From: | Teodor Sigaev <teodor(at)sigaev(dot)ru> |
---|---|
To: | Tomas Vondra <tomas(dot)vondra(at)2ndquadrant(dot)com>, Pgsql Hackers <pgsql-hackers(at)postgresql(dot)org> |
Subject: | Re: POC: GROUP BY optimization |
Date: | 2018-06-13 16:56:00 |
Message-ID: | 24c773b8-3a9a-8fe9-610d-01145758931b@sigaev.ru |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
> I.e. we already do reorder the group clauses to match ORDER BY, to only
> require a single sort. This happens in preprocess_groupclause(), which
> also explains the reasoning behind that.
Huh. I missed that. That means group_keys_reorder_by_pathkeys() call inside
get_cheapest_group_keys_order() duplicates work of preprocess_groupclause().
And so it's possible to replace it to simple counting number of the same
pathkeys in beginning of lists. Or remove most part of preprocess_groupclause()
- but it seems to me we should use first option, preprocess_groupclause() is
simpler, it doesn't operate with pathkeys only with SortGroupClause which is
simpler.
BTW, incremental sort path provides pathkeys_common(), exactly what we need.
> I wonder if some of the new code reordering group pathkeys could/should
> be moved here (not sure, maybe it's too early for those decisions). In
> any case, it might be appropriate to update some of the comments before
> preprocess_groupclause() which claim we don't do certain things added by
> the proposed patches.
preprocess_groupclause() is too early step to use something like
group_keys_reorder_by_pathkeys() because pathkeys is not known here yet.
> This probably also somewhat refutes my claim that the order of grouping
> keys is currently fully determined by users (and so they may pick the
> most efficient order), while the reorder-by-ndistinct patch would make
> that impossible. Apparently when there's ORDER BY, we already mess with
> the order of group clauses - there are ways to get around it (subquery
> with OFFSET 0) but it's much less clear.
I like a moment when objections go away :)
--
Teodor Sigaev E-mail: teodor(at)sigaev(dot)ru
WWW: http://www.sigaev.ru/
From | Date | Subject | |
---|---|---|---|
Next Message | Masahiko Sawada | 2018-06-13 17:06:57 | Re: Index maintenance function for BRIN doesn't check RecoveryInProgress() |
Previous Message | amul sul | 2018-06-13 16:55:23 | Re: Partitioning with temp tables is broken |