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
* EvalPlanQual checking.
*
* NOTE: the rewriter's rewriteTargetListIU and rewriteTargetListUD
* routines also do preprocessing of the targetlist. The division of labor
* between here and there is a bit arbitrary and historical.
* The rewriter's rewriteTargetListIU and rewriteTargetListUD routines
* also do preprocessing of the targetlist. The division of labor between
* 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