mirror of
https://github.com/postgres/postgres.git
synced 2025-09-02 04:21:28 +03:00
Block ALTER TABLE .. DROP NOT NULL on columns in replica identity index
Replica identities that depend directly on an index rely on a set of properties, one of them being that all the columns defined in this index have to be marked as NOT NULL. There was a hole in the logic with ALTER TABLE DROP NOT NULL, where it was possible to remove the NOT NULL property of a column part of an index used as replica identity, so block it to avoid problems with logical decoding down the road. The same check was already done columns part of a primary key, so the fix is straight-forward. Author: Haiying Tang, Hou Zhijie Reviewed-by: Dilip Kumar, Michael Paquier Discussion: https://postgr.es/m/OS0PR01MB6113338C102BEE8B2FFC5BD9FB619@OS0PR01MB6113.jpnprd01.prod.outlook.com Backpatch-through: 10
This commit is contained in:
@@ -223,6 +223,10 @@ ALTER TABLE test_replica_identity3 ALTER COLUMN id TYPE bigint;
|
||||
Indexes:
|
||||
"test_replica_identity3_id_key" UNIQUE, btree (id) REPLICA IDENTITY
|
||||
|
||||
-- ALTER TABLE DROP NOT NULL is not allowed for columns part of an index
|
||||
-- used as replica identity.
|
||||
ALTER TABLE test_replica_identity3 ALTER COLUMN id DROP NOT NULL;
|
||||
ERROR: column "id" is in index used as replica identity
|
||||
DROP TABLE test_replica_identity;
|
||||
DROP TABLE test_replica_identity2;
|
||||
DROP TABLE test_replica_identity3;
|
||||
|
@@ -94,6 +94,10 @@ ALTER TABLE test_replica_identity3 REPLICA IDENTITY USING INDEX test_replica_ide
|
||||
ALTER TABLE test_replica_identity3 ALTER COLUMN id TYPE bigint;
|
||||
\d test_replica_identity3
|
||||
|
||||
-- ALTER TABLE DROP NOT NULL is not allowed for columns part of an index
|
||||
-- used as replica identity.
|
||||
ALTER TABLE test_replica_identity3 ALTER COLUMN id DROP NOT NULL;
|
||||
|
||||
DROP TABLE test_replica_identity;
|
||||
DROP TABLE test_replica_identity2;
|
||||
DROP TABLE test_replica_identity3;
|
||||
|
Reference in New Issue
Block a user