Commit 72647ac3 authored by Tom Lane's avatar Tom Lane

Assign collations in partition bound expressions.

Failure to do this can result in errors during evaluation of
the bound expression, as illustrated by the new regression test.

Back-patch to v12 where the ability for partition bounds to be
expressions was added.

Discussion: https://postgr.es/m/CAJV4CdrZ5mKuaEsRSbLf2URQ3h6iMtKD=hik8MaF5WwdmC9uZw@mail.gmail.com
parent 2dfa3fea
...@@ -4209,6 +4209,7 @@ transformPartitionBoundValue(ParseState *pstate, Node *val, ...@@ -4209,6 +4209,7 @@ transformPartitionBoundValue(ParseState *pstate, Node *val,
*/ */
if (!IsA(value, Const)) if (!IsA(value, Const))
{ {
assign_expr_collations(pstate, value);
value = (Node *) expression_planner((Expr *) value); value = (Node *) expression_planner((Expr *) value);
value = (Node *) evaluate_expr((Expr *) value, colType, colTypmod, value = (Node *) evaluate_expr((Expr *) value, colType, colTypmod,
partCollation); partCollation);
......
...@@ -1014,6 +1014,13 @@ DETAIL: Failing row contains (1, null). ...@@ -1014,6 +1014,13 @@ DETAIL: Failing row contains (1, null).
Partition of: parted_notnull_inh_test FOR VALUES IN (1) Partition of: parted_notnull_inh_test FOR VALUES IN (1)
drop table parted_notnull_inh_test; drop table parted_notnull_inh_test;
-- check that collations are assigned in partition bound expressions
create table parted_boolean_col (a bool, b text) partition by list(a);
create table parted_boolean_less partition of parted_boolean_col
for values in ('foo' < 'bar');
create table parted_boolean_greater partition of parted_boolean_col
for values in ('foo' > 'bar');
drop table parted_boolean_col;
-- check for a conflicting COLLATE clause -- check for a conflicting COLLATE clause
create table parted_collate_must_match (a text collate "C", b text collate "C") create table parted_collate_must_match (a text collate "C", b text collate "C")
partition by range (a); partition by range (a);
......
...@@ -801,6 +801,14 @@ insert into parted_notnull_inh_test (b) values (null); ...@@ -801,6 +801,14 @@ insert into parted_notnull_inh_test (b) values (null);
\d parted_notnull_inh_test1 \d parted_notnull_inh_test1
drop table parted_notnull_inh_test; drop table parted_notnull_inh_test;
-- check that collations are assigned in partition bound expressions
create table parted_boolean_col (a bool, b text) partition by list(a);
create table parted_boolean_less partition of parted_boolean_col
for values in ('foo' < 'bar');
create table parted_boolean_greater partition of parted_boolean_col
for values in ('foo' > 'bar');
drop table parted_boolean_col;
-- check for a conflicting COLLATE clause -- check for a conflicting COLLATE clause
create table parted_collate_must_match (a text collate "C", b text collate "C") create table parted_collate_must_match (a text collate "C", b text collate "C")
partition by range (a); partition by range (a);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment