Org.postgresql.util.PSQLException: ERROR : duplicate key value violates unique constraint XXXX
Org.postgresql.util.PSQLException: ERROR : duplicate key value violates unique constraint device_id_key
前幾天在解決現(xiàn)場問題的時(shí)候發(fā)現(xiàn)后臺(tái)報(bào)錯(cuò)duplicate key value violates unique constraint device_id_key.這個(gè)錯(cuò)誤意思是,重復(fù)的鍵值違反了唯一性約束.也就是device表中的id違反了唯一性約束.
出現(xiàn)的原因是: 以device表為列子.id是唯一的且id在數(shù)據(jù)庫中是自增的. 而現(xiàn)在數(shù)據(jù)庫中存在的id的值大于了id現(xiàn)在應(yīng)該自增的值.比如現(xiàn)在數(shù)據(jù)庫device表中現(xiàn)在的id是100,而id自增才增長到95.那你在添加一條數(shù)據(jù)的時(shí)候,id是96,id為96的這條數(shù)據(jù)已經(jīng)有了,所以id就違反了唯一性約束.
解決方案
1.先要查看這張表中已經(jīng)存在的id的最大值是多少. 直接在數(shù)據(jù)庫連接工具中輸入sql查詢.
Select max(id) from device;2.查詢這張表的id的自增序列是多少.
Select nextval(‘device_id_seq’);3 . 如果這張表的id的最大值大于 id的自增序列的值.那就證明添加的時(shí)候會(huì)出現(xiàn)id被占用,而導(dǎo)致id違反唯一性約束的問題. 我們只需要重新給id的自增序列賦值,賦一個(gè)大于現(xiàn)在表中id的最大值就可以了.
SELECT setval('device_id_seq', xxx);4.在重新查詢一下,id的自增序列的值是多少,如果和上一步我們設(shè)置的值一樣的話,就沒有問題了.
Select nextval(‘device_id_seq’);總結(jié)
以上是生活随笔為你收集整理的Org.postgresql.util.PSQLException: ERROR : duplicate key value violates unique constraint XXXX的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: YOLOv5首发改进最新CVPR2023
- 下一篇: Flink程序加载数据源(3)自定义数据