Thread: pgsql: Choose FK name correctly during partition attachment

pgsql: Choose FK name correctly during partition attachment

From
Alvaro Herrera
Date:
Choose FK name correctly during partition attachment

During ALTER TABLE ATTACH PARTITION, if the name of a parent's foreign
key constraint is already used on the partition, the code tries to
choose another one before the FK attributes list has been populated,
so the resulting constraint name was "<relname>__fkey" instead of
"<relname>_<attrs>_fkey".  Repair, and add a test case.

Backpatch to 12.  In 11, the code to attach a partition was not smart
enough to cope with conflicting constraint names, so the problem doesn't
exist there.

Author: Jehan-Guillaume de Rorthais <jgdr@dalibo.com>
Discussion: https://postgr.es/m/20220901184156.738ebee5@karst

Branch
------
REL_14_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/640c20d6266ddc89e7969c697681d3f869f92dfb

Modified Files
--------------
src/backend/commands/tablecmds.c           | 20 ++++++++++----------
src/test/regress/input/constraints.source  | 19 +++++++++++++++++++
src/test/regress/output/constraints.source | 23 +++++++++++++++++++++++
3 files changed, 52 insertions(+), 10 deletions(-)