]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Build EC members for child join rels in the right memory context.
authorTom Lane <tgl@sss.pgh.pa.us>
Tue, 6 Oct 2020 15:43:53 +0000 (11:43 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Tue, 6 Oct 2020 15:43:53 +0000 (11:43 -0400)
commitd7885b1f87fa066606acc54700edee28812be8c1
tree389c1ca0d7d32c4a33bc0f81940e9acf5f373039
parent1b22224945e1e7162fe92aecb1cd2b373fba24c2
Build EC members for child join rels in the right memory context.

This patch prevents crashes or wrong plans when partition-wise joins
are considered during GEQO planning, as a consequence of the
EquivalenceClass data structures becoming corrupt after a GEQO
context reset.

A remaining problem is that successive GEQO cycles will make multiple
copies of the required EC members, since add_child_join_rel_equivalences
has no idea that such members might exist already.  For now we'll just
live with that.  The lack of field complaints of crashes suggests that
this is a mighty little-used situation.

Back-patch to v12 where this code was introduced.

Discussion: https://postgr.es/m/1683100.1601860653@sss.pgh.pa.us
src/backend/optimizer/path/equivclass.c