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/nodes/copyfuncs.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/nodes/copyfuncs.c')
-rw-r--r-- | src/backend/nodes/copyfuncs.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/backend/nodes/copyfuncs.c b/src/backend/nodes/copyfuncs.c index c0d2294317e..c9133ddfa19 100644 --- a/src/backend/nodes/copyfuncs.c +++ b/src/backend/nodes/copyfuncs.c @@ -1951,6 +1951,7 @@ _copyRangeTblEntry(RangeTblEntry *from) COPY_NODE_FIELD(funccoltypmods); COPY_NODE_FIELD(funccolcollations); COPY_NODE_FIELD(values_lists); + COPY_NODE_FIELD(values_collations); COPY_STRING_FIELD(ctename); COPY_SCALAR_FIELD(ctelevelsup); COPY_SCALAR_FIELD(self_reference); |