亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2024年03月22日 10:05:57   作者:jwensh  
這篇文章主要介紹了Oracle插入數(shù)據(jù)時(shí)出現(xiàn)ORA-00001:unique?constraint問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

背景

后臺(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)文章

最新評(píng)論