diff --git a/src/backend/executor/execMain.c b/src/backend/executor/execMain.c index b22de78516..040e9a916a 100644 --- a/src/backend/executor/execMain.c +++ b/src/backend/executor/execMain.c @@ -1956,6 +1956,7 @@ ExecConstraints(ResultRelInfo *resultRelInfo, if (map != NULL) { tuple = do_convert_tuple(tuple, map); + ExecSetSlotDescriptor(slot, tupdesc); ExecStoreTuple(tuple, slot, InvalidBuffer, false); } } @@ -2003,6 +2004,7 @@ ExecConstraints(ResultRelInfo *resultRelInfo, if (map != NULL) { tuple = do_convert_tuple(tuple, map); + ExecSetSlotDescriptor(slot, tupdesc); ExecStoreTuple(tuple, slot, InvalidBuffer, false); } } @@ -2112,6 +2114,7 @@ ExecWithCheckOptions(WCOKind kind, ResultRelInfo *resultRelInfo, if (map != NULL) { tuple = do_convert_tuple(tuple, map); + ExecSetSlotDescriptor(slot, tupdesc); ExecStoreTuple(tuple, slot, InvalidBuffer, false); } } diff --git a/src/test/regress/expected/insert.out b/src/test/regress/expected/insert.out index c608ce377f..0eaa47fb2b 100644 --- a/src/test/regress/expected/insert.out +++ b/src/test/regress/expected/insert.out @@ -410,6 +410,14 @@ with ins (a, b, c) as mlparted4 | 1 | 30 | 39 (5 rows) +alter table mlparted add c text; +create table mlparted5 (c text, a int not null, b int not null); +alter table mlparted attach partition mlparted5 for values from (1, 40) to (1, 50); +alter table mlparted add constraint check_b check (a = 1 and b < 45); +insert into mlparted values (1, 45, 'bah'); +ERROR: new row for relation "mlparted5" violates check constraint "check_b" +DETAIL: Failing row contains (1, 45, bah). +drop table mlparted5; -- check that message shown after failure to find a partition shows the -- appropriate key description (or none) in various situations create table key_desc (a int, b int) partition by list ((a+0)); diff --git a/src/test/regress/expected/updatable_views.out b/src/test/regress/expected/updatable_views.out index caca81a70b..eab5c0334c 100644 --- a/src/test/regress/expected/updatable_views.out +++ b/src/test/regress/expected/updatable_views.out @@ -2368,8 +2368,8 @@ DETAIL: Failing row contains (-1, invalid). DROP VIEW v1; DROP TABLE t1; -- check that an auto-updatable view on a partitioned table works correctly -create table pt (a int, b int) partition by range (a, b); -create table pt1 (b int not null, a int not null) partition by range (b); +create table pt (a int, b int, v varchar) partition by range (a, b); +create table pt1 (b int not null, v varchar, a int not null) partition by range (b); create table pt11 (like pt1); alter table pt11 drop a; alter table pt11 add a int; @@ -2412,18 +2412,19 @@ select table_name, column_name, is_updatable ------------+-------------+-------------- ptv | a | YES ptv | b | YES -(2 rows) + ptv | v | YES +(3 rows) insert into ptv values (1, 2); select tableoid::regclass, * from pt; - tableoid | a | b -----------+---+--- - pt11 | 1 | 2 + tableoid | a | b | v +----------+---+---+--- + pt11 | 1 | 2 | (1 row) create view ptv_wco as select * from pt where a = 0 with check option; insert into ptv_wco values (1, 2); ERROR: new row violates check option for view "ptv_wco" -DETAIL: Failing row contains (1, 2). +DETAIL: Failing row contains (1, 2, null). drop view ptv, ptv_wco; drop table pt, pt1, pt11; diff --git a/src/test/regress/sql/insert.sql b/src/test/regress/sql/insert.sql index 7666a7d6ca..89e503bff8 100644 --- a/src/test/regress/sql/insert.sql +++ b/src/test/regress/sql/insert.sql @@ -263,6 +263,13 @@ with ins (a, b, c) as (insert into mlparted (b, a) select s.a, 1 from generate_series(2, 39) s(a) returning tableoid::regclass, *) select a, b, min(c), max(c) from ins group by a, b order by 1; +alter table mlparted add c text; +create table mlparted5 (c text, a int not null, b int not null); +alter table mlparted attach partition mlparted5 for values from (1, 40) to (1, 50); +alter table mlparted add constraint check_b check (a = 1 and b < 45); +insert into mlparted values (1, 45, 'bah'); +drop table mlparted5; + -- check that message shown after failure to find a partition shows the -- appropriate key description (or none) in various situations create table key_desc (a int, b int) partition by list ((a+0)); diff --git a/src/test/regress/sql/updatable_views.sql b/src/test/regress/sql/updatable_views.sql index 6a9958d38b..2ede44c02b 100644 --- a/src/test/regress/sql/updatable_views.sql +++ b/src/test/regress/sql/updatable_views.sql @@ -1114,8 +1114,8 @@ DROP VIEW v1; DROP TABLE t1; -- check that an auto-updatable view on a partitioned table works correctly -create table pt (a int, b int) partition by range (a, b); -create table pt1 (b int not null, a int not null) partition by range (b); +create table pt (a int, b int, v varchar) partition by range (a, b); +create table pt1 (b int not null, v varchar, a int not null) partition by range (b); create table pt11 (like pt1); alter table pt11 drop a; alter table pt11 add a int;