Fix handling of inherited check constraints in ALTER COLUMN TYPE.
This case got broken in 8.4 by the addition of an error check that
complains if ALTER TABLE ONLY is used on a table that has children.
We do use ONLY for this situation, but it's okay because the necessary
recursion occurs at a higher level. So we need to have a separate
flag to suppress recursion without making the error check.
Reported and patched by Pavan Deolasee, with some editorial adjustments by
me. Back-patch to 8.4, since this is a regression of functionality that
worked in earlier branches.
src/backend/commands/tablecmds.c | 43 ++++++++++++++++++++++-------
src/include/nodes/parsenodes.h | 4 ++-
src/test/regress/expected/alter_table.out | 22 +++++++++++++++
src/test/regress/sql/alter_table.sql | 7 +++++
4 files changed, 65 insertions(+), 11 deletions(-)
pgsql-committers by date
|Next:||From: Bruce Momjian||Date: 2012-11-06 19:29:01|
|Subject: pgsql: In pg_upgrade, set synchronous_commit=off for the new cluster,t|
|Previous:||From: User Fxjr||Date: 2012-11-04 23:09:37|
|Subject: npgsql - Npgsql2: Fixed test data insertion and function creation |