Org.postgresql.util.PSQLException: ERROR : duplicate key value violates unique constraint XXXX
生活随笔
收集整理的這篇文章主要介紹了
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
前幾天在解決現場問題的時候發現后臺報錯duplicate key value violates unique constraint device_id_key.這個錯誤意思是,重復的鍵值違反了唯一性約束.也就是device表中的id違反了唯一性約束.
出現的原因是: 以device表為列子.id是唯一的且id在數據庫中是自增的. 而現在數據庫中存在的id的值大于了id現在應該自增的值.比如現在數據庫device表中現在的id是100,而id自增才增長到95.那你在添加一條數據的時候,id是96,id為96的這條數據已經有了,所以id就違反了唯一性約束.
解決方案
1.先要查看這張表中已經存在的id的最大值是多少. 直接在數據庫連接工具中輸入sql查詢.
Select max(id) from device;2.查詢這張表的id的自增序列是多少.
Select nextval(‘device_id_seq’);3 . 如果這張表的id的最大值大于 id的自增序列的值.那就證明添加的時候會出現id被占用,而導致id違反唯一性約束的問題. 我們只需要重新給id的自增序列賦值,賦一個大于現在表中id的最大值就可以了.
SELECT setval('device_id_seq', xxx);4.在重新查詢一下,id的自增序列的值是多少,如果和上一步我們設置的值一樣的話,就沒有問題了.
Select nextval(‘device_id_seq’);總結
以上是生活随笔為你收集整理的Org.postgresql.util.PSQLException: ERROR : duplicate key value violates unique constraint XXXX的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: YOLOv5首发改进最新CVPR2023
- 下一篇: linux cmake编译源码,linu