linuxsir首页 LinuxSir.Org | Linux、BSD、Solaris、Unix | 开源传万世,因有我参与欢迎您!
网站首页 | 设为首页 | 加入收藏
您所在的位置:主页 > Linux数据库 >

Oracle插入数据时出现 ORA

时间:2019-06-11  来源:未知  作者:admin666

背景:

后台服务测试过程中,发现往Oracle数据库表中插数据出现一个错误 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

原因:

根据提示的索引号,找到了表中的字段 SEQ_NO ,发现是因为测试数据库是由另一个数据库同步过来的,表中自动的序列号被打乱,导致下一次插入数据的时候,sql自动生成的序列号所在的位子已经有了数据,所以导致了唯一约束错误。当然数据的错误删除和人为的错误操作都会导致这个问题。

解决:

首先,我们可以查询一下这个表的序列号在什么位子(我的表为TBL_ACM_CLAIM):
select SEQ_ACM_CLAIM.NEXTVAL  from DUAL

不要随便执行这个sql,因为没执行一次,索引值都会自增+1;查询到结果后,对比表中现有的数据,进行对比,如果表中SEQ_NO的值大于查询到的值,就将把索引值进行更新,设定序列步长为100(一般都是1),执行下面sql:
alter sequence SEQ_ACM_CLAIM increment by 100

注意:SEQ_ACM_CLAIM 是不是表名,还有就是索引值不能修改当前值,只能修改增加,不能减少。

提示:

查询所有所有索引:
select * from user_sequences;

删除索引:
drop sequence SEQ_ACM_CLAIM;
创建索引:
CREATE UNIQUE INDEX SEQ_ACM_CLAIM ON TBL_ACM_CLAIM(SEQ_NO);

总结:

删库到跑路,一秒就够。

更多Oracle相关信息见Oracle 专题页面 https://www.linuxidc.com/topicnews.aspx?tid=12

Linux公社的RSS地址:https://www.linuxidc.com/rssFeed.aspx

友情链接
  • 适用于Windows 10的Microsoft Edge Dev 76.0.172.0已发布
  • 程序员人脸识别成人视频中的女性引发争议
  • 安装Oracle 11g RAC时报Failed to run “oifcfg” 和 找不到集群
  • Unity Tech正式宣布推出适用于Linux的新Unity编辑器
  • Oracle插入数据时出现 ORA
  • Phoronix Test Suite 8.8.1 发布
  • MySQL中使用group
  • X.Org Server 1.20.5 发布,一些XWayland和GLAMOR修复
  • MySQL中group by 与 order by 一起使用排序问题
  • Fedora 31考虑使用Zstd压缩其RPM包而不是XZ
  • PostgreSQL数据库安装部署
  • Google Chrome 成为互联网的看门人
  • Redis中Scan命令的使用
  • 华为Mate 20 Pro重回Android Q Beta支持名单中
  • TypeScript 3.5 发布,新增Omit 辅助类型
  • Redis集群模式下的redis
  • PyPI宣布2FA用于提高Python包下载安全性
  • MuseScore 3.1 发布,音乐制谱软件
  • openSUSE Leap 42.3 Linux操作系统将于2019年6月30日停止支持
  • Linux新闻 第974页
  • 美国司法部正计划对谷歌进行反垄断调查
  • 超六成Windows 10用户运行着一年前的版本
  • Linux里如何配置本地yum源和外网源
  • MySQL中group by 与 order by 一起使用排序问题
  • yum更换国内源及yum下载rpm包
  • MySQL中使用group_concat遇到的问题及解决
  • Linux 定时任务 Crontab
  • Oracle插入数据时出现 ORA-00001: unique constraint
  • Yii2 的安装及简单使用
  • SpringBoot配置加载顺序
  • git merge的使用
  • 编写shell脚本自动生成开头注释简介
  • JDK动态代理在RPC框架中的应用
  • 将Fedora 29升级到Fedora 30
  • Linux touch命令详述
  • Java实现对图片透明化处理
  • 如何在Ubuntu 18.04,19.04中安装uGet 2.2.2
  • ACL权限设置命令setfacl和getfacl命令
  • Nginx+Tomcat8+Memcached实现负载均衡及session共享
  • Redis集群模式下的redis-py-cluster方式读写测试
  • Linux命令 - facl文件系统的访问控制列表详解
  • 在Linux系统中创建SSH服务器别名
  • Redis中Scan命令的使用
  • Apache Camel XML外部实体注入漏洞(CVE-2019-0188)
  • shell脚本里使用echo输出颜色
  • PostgreSQL数据库安装部署
  • Apache Hadoop远程权限提升漏洞(CVE-2018-8029)
  • Google Chrome成为互联网的看门人
  • 欧洲杯直播频道
  • 彩票平台
  • 澳门银河国际网站
  • 28评测网
  • 新利棋牌
  • 中国娱乐场