Oracle插入數(shù)據(jù)時出現(xiàn)ORA-00001:unique?constraint問題
背景
后臺服務(wù)測試過程中,發(fā)現(xiàn)往oracle數(shù)據(jù)庫表中插數(shù)據(jù)出現(xiàn)一個錯誤 unique constraint
如下:
### Error updating database. Cause: java.sql.SQLIntegrityConstraintViolationException: ORA-00001: unique constraint (TEST53.SYS_C0032604) violated
### The error may exist in class path resource [sqlmapper/ACMClaimMapper.xml]
### The error may involve com.las.core.dal.dao.ACMClaimMapper.insert-Inline
### The error occurred while setting parameters
### SQL: insert into TBL_ACM_CLAIM ( SEQ_NO, ACCT_NO, FUND_CHANNEL,STATUS,CREATE_DATE,CSM_NAME,CSM_CARD,LOAN_DATE,LOAN_AMT ) values ( ?,?,?,?,?,?,?,?,? )
### Cause: java.sql.SQLIntegrityConstraintViolationException: ORA-00001: unique constraint (TEST53.SYS_C0032604) violated
; SQL []; ORA-00001: unique constraint (TEST53.SYS_C0032604) violated
; nested exception is java.sql.SQLIntegrityConstraintViolationException: ORA-00001: unique constraint (TEST53.SYS_C0032604) violated
原因
根據(jù)提示的索引號,找到了表中的字段“SEQ_NO”
發(fā)現(xiàn)是因為測試數(shù)據(jù)庫是由另一個數(shù)據(jù)庫同步過來的,表中自動的序列號被打亂
導(dǎo)致下一次插入數(shù)據(jù)的時候,sql自動生成的序列號所在的位子已經(jīng)有了數(shù)據(jù),所以導(dǎo)致了唯一約束錯誤。
當然數(shù)據(jù)的錯誤刪除和人為的錯誤操作都會導(dǎo)致這個問題。
解決
首先,
我們可以查詢一下這個表的序列號在什么位子(我的表為TBL_ACM_CLAIM):
select SEQ_ACM_CLAIM.NEXTVAL from DUAL
不要隨便執(zhí)行這個sql,因為沒執(zhí)行一次,索引值都會自增+1;
查詢到結(jié)果后,對比表中現(xiàn)有的數(shù)據(jù),進行對比
如果表中SEQ_NO的值大于查詢到的值,就將把索引值進行更新,設(shè)定序列步長為100(一般都是1)
執(zhí)行下面sql:
alter sequence SEQ_ACM_CLAIM increment by 100
注意:SEQ_ACM_CLAIM 是不是表名,還有就是索引值不能修改當前值,只能修改增加,不能減少。
提示:
- 查詢所有所有索引:
select * from user_sequences;
- 刪除索引:
drop sequence SEQ_ACM_CLAIM;
- 創(chuàng)建索引:
CREATE UNIQUE INDEX SEQ_ACM_CLAIM ON TBL_ACM_CLAIM(SEQ_NO);
總結(jié)
刪庫到跑路,一秒就夠。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Linux環(huán)境下Oracle安裝參數(shù)設(shè)置方法詳解
這篇文章主要介紹了Linux環(huán)境下Oracle安裝參數(shù)設(shè)置方法,本文通過代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-06-06Oracle數(shù)據(jù)庫如何使用exp和imp方式導(dǎo)數(shù)據(jù)
在平時的工作中,我們難免會遇到要備份數(shù)據(jù),當然用pl/sql可以實現(xiàn)通過導(dǎo)出數(shù)據(jù)來備份數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫如何使用exp和imp方式導(dǎo)數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2022-06-06解決The?Network?Adapter?could?not?establish?the?conn問題
這篇文章主要介紹了解決The?Network?Adapter?could?not?establish?the?conn問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02