欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle插入數(shù)據(jù)時出現(xiàn)ORA-00001:unique?constraint問題

 更新時間:2024年03月22日 10:05:57   作者:jwensh  
這篇文章主要介紹了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)文章

最新評論