Oracle插入數(shù)據(jù)時(shí)出現(xiàn)ORA-00001:unique?constraint問題
背景
后臺(tái)服務(wù)測試過程中,發(fā)現(xiàn)往oracle數(shù)據(jù)庫表中插數(shù)據(jù)出現(xiàn)一個(gè)錯(cuò)誤 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ù)提示的索引號(hào),找到了表中的字段“SEQ_NO”
發(fā)現(xiàn)是因?yàn)闇y試數(shù)據(jù)庫是由另一個(gè)數(shù)據(jù)庫同步過來的,表中自動(dòng)的序列號(hào)被打亂
導(dǎo)致下一次插入數(shù)據(jù)的時(shí)候,sql自動(dòng)生成的序列號(hào)所在的位子已經(jīng)有了數(shù)據(jù),所以導(dǎo)致了唯一約束錯(cuò)誤。
當(dāng)然數(shù)據(jù)的錯(cuò)誤刪除和人為的錯(cuò)誤操作都會(huì)導(dǎo)致這個(gè)問題。
解決
首先,
我們可以查詢一下這個(gè)表的序列號(hào)在什么位子(我的表為TBL_ACM_CLAIM):
select SEQ_ACM_CLAIM.NEXTVAL from DUAL
不要隨便執(zhí)行這個(gè)sql,因?yàn)闆]執(zhí)行一次,索引值都會(huì)自增+1;
查詢到結(jié)果后,對(duì)比表中現(xiàn)有的數(shù)據(jù),進(jìn)行對(duì)比
如果表中SEQ_NO的值大于查詢到的值,就將把索引值進(jìn)行更新,設(shè)定序列步長為100(一般都是1)
執(zhí)行下面sql:
alter sequence SEQ_ACM_CLAIM increment by 100
注意:SEQ_ACM_CLAIM 是不是表名,還有就是索引值不能修改當(dāng)前值,只能修改增加,不能減少。
提示:
- 查詢所有所有索引:
select * from user_sequences;
- 刪除索引:
drop sequence SEQ_ACM_CLAIM;
- 創(chuàng)建索引:
CREATE UNIQUE INDEX SEQ_ACM_CLAIM ON TBL_ACM_CLAIM(SEQ_NO);
總結(jié)
刪庫到跑路,一秒就夠。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Linux環(huán)境下Oracle安裝參數(shù)設(shè)置方法詳解
這篇文章主要介紹了Linux環(huán)境下Oracle安裝參數(shù)設(shè)置方法,本文通過代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-06-06Oracle數(shù)據(jù)庫如何使用exp和imp方式導(dǎo)數(shù)據(jù)
在平時(shí)的工作中,我們難免會(huì)遇到要備份數(shù)據(jù),當(dāng)然用pl/sql可以實(shí)現(xiàn)通過導(dǎo)出數(shù)據(jù)來備份數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫如何使用exp和imp方式導(dǎo)數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2022-06-06Oracle SQL性能優(yōu)化系列學(xué)習(xí)二
Oracle SQL性能優(yōu)化系列學(xué)習(xí)二...2007-03-03解決The?Network?Adapter?could?not?establish?the?conn問題
這篇文章主要介紹了解決The?Network?Adapter?could?not?establish?the?conn問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02解決ORA-12154 TNS無法解析指定的連接標(biāo)識(shí)符問題
Oracle11g server 64bit服務(wù)器端安裝在Windows Server2008 Enterprise上,安裝Oracle11g client 32bit,通過SQL Plus以sysdba身份連接數(shù)據(jù)庫,并且創(chuàng)建表空間、用戶、授權(quán)成功,在連接數(shù)據(jù)庫時(shí)出現(xiàn)問題,下面講解ORA-12154無法解析指定的連接標(biāo)識(shí)符問題,感興趣的朋友一起看看2024-01-01