Cara Anda menamai indeks Anda, saya berasumsi Anda tidak memiliki batasan pada kolom tersebut, tetapi UNIQUE INDEX
:
CREATE TABLE T (a INT PRIMARY KEY, b INT, c INT);
CREATE UNIQUE INDEX u ON t(b);
INSERT INTO T (a, b, c)
VALUES (1, 2, 3)
ON CONFLICT ON CONSTRAINT u
DO UPDATE SET c = 4
RETURNING *;
Di atas menghasilkan:
[42704]: ERROR: constraint "u" for table "t" does not exist
Namun, ubah indeks menjadi batasan:
DROP INDEX u;
ALTER TABLE t ADD CONSTRAINT u UNIQUE (b);
Dan INSERT
pernyataan sekarang berfungsi.
Lihat penjelasan di sini tentang perbedaan antara batasan unik dan indeks unik . Ini tidak benar-benar terkait dengan jOOQ