pgsql: Improve RowMark handling during Self-Join Elimination
От | Alexander Korotkov |
---|---|
Тема | pgsql: Improve RowMark handling during Self-Join Elimination |
Дата | |
Msg-id | E1uqqpz-001k6N-0k@gemulon.postgresql.org обсуждение исходный текст |
Список | pgsql-committers |
Improve RowMark handling during Self-Join Elimination The Self-Join Elimination SJE feature messes up keeping and removing RowMark's in remove_self_joins_one_group(). That didn't lead to user-level error, because the planned RowMark is only used to reference a rtable entry in later execution stages. An RTE entry for keeping and removing relations is identical and refers to the same relation OID. To reduce confusion and prevent future issues, this commit cleans up the code and fixes the incorrect behaviour. Furthermore, it includes sanity checks in setrefs.c on existing non-null RTE and RelOptInfo entries for each RowMark. Discussion: https://postgr.es/m/18c6bd6c-6d2a-419a-b0da-dfedef34b585%40gmail.com Author: Andrei Lepikhov <lepihov@gmail.com> Reviewed-by: Greg Sabino Mullane <htamfids@gmail.com> Backpatch-through: 18 Branch ------ master Details ------- https://git.postgresql.org/pg/commitdiff/5f6f951f88e53630b3ebe9bde762a9612ca6202f Modified Files -------------- src/backend/optimizer/plan/analyzejoins.c | 9 ++++++--- src/backend/optimizer/plan/setrefs.c | 4 ++++ 2 files changed, 10 insertions(+), 3 deletions(-)
В списке pgsql-committers по дате отправления: