Jerry Brenner <jbren...@guidewire.com> writes:
> We are on Postgres 15.5 (Aurora)  and capturing query plans via
> auto_explain.  We are seeing a large number of query plans for 2 queries
> that have 12 tables.  Every fast (or "fast enough") plan has a left deep
> tree and every slow plan has a bushy tree.  Is there a way to determine if
> a plan was generated by GECO?

> We have from_collapse_limit, join_collapse_limit and geqo_threshold all set
> to 12.

If there are 12 tables used in the query, then setting the collapse
limits to 12 would allow the join search to be collapsed into a single
problem, and then it would *always* go to GEQO because we invoke GEQO
if the join problem involves >= geqo_threshold tables.  You might want
to rethink having those settings equal to each other.

> I've manually explained plans and haven't seen the problem,

My guess is that GEQO usually finds one of the better plans, but
when its randomized search is particularly unlucky it fails to.
Try bumping geqo_threshold to more than 12, and note whether that
results in unacceptable planning time for these queries.  If not,
leave it at the higher value.

                        regards, tom lane


Reply via email to