diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2011-04-18 15:31:52 -0400 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2011-04-18 15:31:52 -0400 |
commit | 918854cc08868d569aad3bdf2529fc61c66ecde5 (patch) | |
tree | e6175eed7446145d62b0bb707d83f29209837556 /src/backend/optimizer/plan/setrefs.c | |
parent | 04db0fdbfa9382730bb65f94bca2cd8063a3456a (diff) |
Fix handling of collations in multi-row VALUES constructs.
Per spec we ought to apply select_common_collation() across the expressions
in each column of the VALUES table. The original coding was just taking
the first row and assuming it was representative.
This patch adds a field to struct RangeTblEntry to carry the resolved
collations, so initdb is forced for changes in stored rule representation.
Diffstat (limited to 'src/backend/optimizer/plan/setrefs.c')
-rw-r--r-- | src/backend/optimizer/plan/setrefs.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/backend/optimizer/plan/setrefs.c b/src/backend/optimizer/plan/setrefs.c index 432d6483be1..60a1484c992 100644 --- a/src/backend/optimizer/plan/setrefs.c +++ b/src/backend/optimizer/plan/setrefs.c @@ -216,6 +216,7 @@ set_plan_references(PlannerGlobal *glob, Plan *plan, newrte->funccoltypmods = NIL; newrte->funccolcollations = NIL; newrte->values_lists = NIL; + newrte->values_collations = NIL; newrte->ctecoltypes = NIL; newrte->ctecoltypmods = NIL; newrte->ctecolcollations = NIL; |