From: | PG Bug reporting form <noreply(at)postgresql(dot)org> |
---|---|
To: | pgsql-bugs(at)lists(dot)postgresql(dot)org |
Cc: | gweatherby(at)uchc(dot)edu |
Subject: | BUG #18886: identity duplicate key |
Date: | 2025-04-09 23:04:20 |
Message-ID: | 18886-7a7ebc1b03f6ad9c@postgresql.org |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
The following bug has been logged on the website:
Bug reference: 18886
Logged by: Gerard Weatherby
Email address: gweatherby(at)uchc(dot)edu
PostgreSQL version: 17.2
Operating system: Ubuntu 24
Description:
I observed this:
registry=# SELECT last_value, is_called FROM performance.vm_load_id_seq;
last_value | is_called
------------+-----------
12935994 | t
(1 row)
registry=# \d performance.vm_load
Table "performance.vm_load"
Column | Type | Collation | Nullable |
Default
-----------+--------------------------+-----------+----------+------------------------------
id | integer | | not null | generated
always as identity
vm_id | integer | | not null |
load15 | double precision | | not null |
idle | double precision | | not null |
stat_time | timestamp with time zone | | not null |
Indexes:
"vm_load_pk" PRIMARY KEY, btree (id)
"vm_load_id_vm_id_stat_time_index" btree (id, vm_id, stat_time)
"vm_load_stat_time_index" btree (stat_time)
Foreign-key constraints:
"vm_load_virtual_machines_id_fk" FOREIGN KEY (vm_id) REFERENCES
performance.virtual_machines(id) ON UPDATE RESTRICT ON DELETE RESTRICT
registry=# INSERT INTO performance.vm_load(vm_id,load15,idle,stat_time)
values(437,0.0,94.31128026560856,'2025-04-09T22:25:26.326639+00:00'::timestamptz)
;
ERROR: duplicate key value violates unique constraint "vm_load_pk"
DETAIL: Key (id)=(1314208) already exists.
Unable to figure out what was going on, I did this, and it seemed to fix the
issue:
-- Step 1: Drop the identity from the id column
ALTER TABLE performance.vm_load
ALTER COLUMN id DROP IDENTITY IF EXISTS;
-- Step 2: Re-add the identity (you can choose BY DEFAULT or ALWAYS)
ALTER TABLE performance.vm_load
ALTER COLUMN id ADD GENERATED ALWAYS AS IDENTITY;
-- Step 3: (Optional but recommended) realign the sequence
-- In case rows were added manually and the sequence is behind
SELECT setval(
pg_get_serial_sequence('performance.vm_load', 'id'),
(SELECT MAX(id) FROM performance.vm_load)
);
Note: at one point the id column was "default" as identity instead of
"always". I'm not aware of any inserts that tried to set the id explicitly.
From | Date | Subject | |
---|---|---|---|
Next Message | Thomas Munro | 2025-04-09 23:49:18 | Re: PostgreSQL v15.12 fails to perform PG_UPGRADE from v13 and v9 on Windows |
Previous Message | Tomas Vondra | 2025-04-09 22:47:43 | Re: BUG #18885: ERROR: corrupt MVNDistinct entry - 2 |