From: | Álvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org> |
---|---|
To: | pgsql-committers(at)lists(dot)postgresql(dot)org |
Subject: | pgsql: Elide not-null constraint checks on child tables during PK creat |
Date: | 2025-04-16 20:02:33 |
Message-ID: | E1u58xt-000NUi-05@gemulon.postgresql.org |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-committers |
Elide not-null constraint checks on child tables during PK creation
We were unnecessarily acquiring AccessExclusiveLock on all child tables
when "ALTER TABLE ONLY sometab ADD PRIMARY KEY" was run on their parent
table, an oversight in commit 14e87ffa5c54. This caused deadlocks
during pg_restore of partitioned tables.
The reason to acquire the AEL was that we need to verify that child
tables have the involved columns already marked as not-null; but if the
parent table has an inheritable not-null constraint, then all children
must necessarily be in the correct state already, so we can skip the
check, which avoids acquiring the lock. Reorder the code so that it
works that way. This doesn't change things in the case where the
constraint doesn't exist, but that case is of lesser importance because
it doesn't occur during parallel pg_restore.
While at it, reword some errmsg() and add errhint() to similar cases in
related but not adjacent code.
Diagnosed-by: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Reviewed-by: Tender Wang <tndrwang(at)gmail(dot)com>
Discussion: https://postgr.es/m/67469c1c-38bc-7d94-918a-67033f5dd731@gmx.net
Discussion: https://postgr.es/m/2045026.1743801143@sss.pgh.pa.us
Discussion: https://postgr.es/m/1280408.1744650810@sss.pgh.pa.us
Branch
------
master
Details
-------
https://git.postgresql.org/pg/commitdiff/11ff192b5bb707ba9ec13a0b6c7468874403abb3
Modified Files
--------------
src/backend/catalog/pg_constraint.c | 7 +-
src/backend/commands/tablecmds.c | 145 ++++++++++++++++++------------
src/test/regress/expected/constraints.out | 32 +++++--
src/test/regress/expected/inherit.out | 3 +
src/test/regress/sql/constraints.sql | 14 +++
5 files changed, 136 insertions(+), 65 deletions(-)
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2025-04-16 21:59:13 | pgsql: Sync declarations and definitions of two new tablecmds.c functio |
Previous Message | Daniel Gustafsson | 2025-04-16 18:25:01 | Re: pgsql: Add support for basic NUMA awareness |