1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-24 01:29:19 +03:00

Add some comments about division of labor between rewriter and planner.

The rationale for the way targetlist processing is done wasn't clearly
stated anywhere, and I for one had forgotten some of the details.  Having
just painfully re-learned them, add some breadcrumbs for the next person.
This commit is contained in:
Tom Lane
2015-12-29 18:50:35 -05:00
parent fd19525756
commit efe4c9d704

View File

@@ -9,9 +9,22 @@
* list and row ID information needed for SELECT FOR UPDATE locking and/or * list and row ID information needed for SELECT FOR UPDATE locking and/or
* EvalPlanQual checking. * EvalPlanQual checking.
* *
* NOTE: the rewriter's rewriteTargetListIU and rewriteTargetListUD * The rewriter's rewriteTargetListIU and rewriteTargetListUD routines
* routines also do preprocessing of the targetlist. The division of labor * also do preprocessing of the targetlist. The division of labor between
* between here and there is a bit arbitrary and historical. * here and there is partially historical, but it's not entirely arbitrary.
* In particular, consider an UPDATE across an inheritance tree. What the
* rewriter does need be done only once (because it depends only on the
* properties of the parent relation). What's done here has to be done over
* again for each child relation, because it depends on the column list of
* the child, which might have more columns and/or a different column order
* than the parent.
*
* The fact that rewriteTargetListIU sorts non-resjunk tlist entries by column
* position, which expand_targetlist depends on, violates the above comment
* because the sorting is only valid for the parent relation. In inherited
* UPDATE cases, adjust_inherited_tlist runs in between to take care of fixing
* the tlists for child tables to keep expand_targetlist happy. We do it like
* that because it's faster in typical non-inherited cases.
* *
* *
* Portions Copyright (c) 1996-2015, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2015, PostgreSQL Global Development Group