summaryrefslogtreecommitdiff
path: root/contrib/pg_stat_statements/sql/planning.sql
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2023-05-26 12:13:19 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2023-05-26 12:13:19 -0400
commit7a844c77ece1bda3b076034bc20142d4bd66db7a (patch)
tree2935adf896a9d3ddc6b15da8db1b710fd0ca96b5 /contrib/pg_stat_statements/sql/planning.sql
parentf4a9422c0c37ba638adbab853b8badb98a53ce04 (diff)
Fix joinclause removal logic to cope with cloned clauses.
When we're deleting a no-op LEFT JOIN from the query, we must remove the join's joinclauses from surviving relations' joininfo lists. The invention of "cloned" clauses in 2489d76c4 broke the logic for that; it'd fail to remove clones that include OJ relids outside the doomed join's min relid sets, which could happen if that join was previously discovered to commute with some other join. This accidentally failed to cause problems in the majority of cases, because we'd never decide that such a cloned clause was evaluatable at any surviving join. However, Richard Guo discovered a case where that did happen, leading to "no relation entry for relid" errors later. Also, adding assertions that a non-removed clause contains no Vars from the doomed join exposes that there are quite a few existing regression test cases where the problem happens but is accidentally not exposed. The fix for this is just to include the target join's commute_above_r and commute_below_l sets in the relid set we test against when deciding whether a join clause is "pushed down" and thus not removable. While at it, do a little refactoring: the join's relid set can be computed inside remove_rel_from_query rather than in the caller. Patch by me; thanks to Richard Guo for review. Discussion: https://postgr.es/m/CAMbWs4_PHrRqTKDNnTRsxxQy6BtYCVKsgXm1_gdN2yQ=kmcO5g@mail.gmail.com
Diffstat (limited to 'contrib/pg_stat_statements/sql/planning.sql')
0 files changed, 0 insertions, 0 deletions