当前位置:网站首页>Duplicate entry ‘XXX‘ for key ‘XXX.PRIMARY‘解决方案。
Duplicate entry ‘XXX‘ for key ‘XXX.PRIMARY‘解决方案。
2022-07-31 04:47:00 【geejkse_seff】
mysql insert时报错:Duplicate entry ‘XXX’ for key ‘XXX.PRIMARY’
今天在插入数据时,出现一个错误
com.jfinal.plugin.activerecord.ActiveRecordException:
com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException:
Duplicate entry 'xxxxxx' for key 'xxxx.PRIMARY'
网上查看说是主键冲突了,但是查看数据库并没有,把所有数据清空,或者把表删了之后,在重新建也还是报同样的错。
…
…
…
最后的结果方案:
- 方案一:设置主键自增,适合主键为int类型(我的主键是varchar)
- 方案二:把insert into 表名() values();修改为:insert ignore into 表名() values(); (问题解决)
MySQL 提供了Ignore 用来避免数据的重复插入.
IGNORE :
若有导致unique key 冲突的记录,则该条记录不会被插入到数据库中.
MySQL INSERT IGNORE 详解请移步:MySQL INSERT IGNORE
原因:这是由于表中对应字段设置了唯一索引,在我们进行逻辑删除时,并没有真正的删除,只是标记为删除状态而已,
当我们再进行新增的时候,由于有唯一索引的限制,导致我们不能进行新增成功,所以报错.
解决方法1:
如果允许的话,把数据库中该字段的唯一索引限制去掉,这样后端可以进行逻辑删除,新增时即使与标记为删除的记录的字段值相等,由于没有唯一索引的限制,可以正常新增
解决方法2:
不需要去掉数据库中的唯一索引限制,但是当后端开发进行删除操作的时候,执行的是物理删除的sql语句(真正的删除),而不是逻辑删除,同时后端用逻辑判断,去查询数据库中是否有相同的编号存在,如果存在,则不允许新增,如果不存在,则可以新增
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
- MySQL database must add, delete, search and modify operations (CRUD)
- input输入框展示两位小数之precision
- volatile内存语义以及实现 -volatile写和读对普通变量的影响
- 剑指offer专项突击版第15天
- Industry-university-research application to build an open source talent ecosystem | 2022 Open Atom Global Open Source Summit Education Sub-Forum was successfully held
- HCIP第十天_BGP路由汇总实验
- Understanding of the presence of a large number of close_wait states
- BUG消灭者!!实用调试技巧超全整理
- MySQL数据库必会的增删查改操作(CRUD)
- VScode+ESP32快速安装ESP-IDF插件
猜你喜欢
ERP生产作业控制 金蝶
两个地址池r2负责管地址池r1负责管dhcp中继
重磅 | 开放原子校源行活动正式启动
ERP Production Operation Control Kingdee
Open Source Database Innovation in the Digital Economy Era | 2022 Open Atom Global Open Source Summit Database Sub-Forum Successfully Held
binom二项分布,
扫雷小游戏——C语言
Basic knowledge of mysql (2)
Lua,ILRuntime, HybridCLR(wolong)/huatuo hot update comparative analysis
Unity手机游戏性能优化系列:针对CPU端的性能调优
随机推荐
【云原生】DevOps(五):集成Harbor
ERROR 1064 (42000) You have an error in your SQL syntax; check the manual that corresponds to your
MATLAB/Simulink & & STM32CubeMX tool chain completes model-based design development (MBD) (three)
The Vue project connects to the MySQL database through node and implements addition, deletion, modification and query operations
[R language] [3] apply, tapply, lapply, sapply, mapply and par function related parameters
数字经济时代的开源数据库创新 | 2022开放原子全球开源峰会数据库分论坛圆满召开
高斯分布及其极大似然估计
扫雷游戏(c语言写)
Interview | Cheng Li, CTO of Alibaba: Cloud + open source together form a credible foundation for the digital world
重磅 | 基金会为白金、黄金、白银捐赠人授牌
(6) Enumeration and annotation
Create componentized development based on ILRuntime hot update
MySQL数据库安装配置保姆级教程(以8.0.29为例)有手就行
Blockbuster | foundation for platinum, gold, silver gave nameboards donors
[debug highlights] Expected input batch_size (1) to match target batch_size (0)
问题1:给你1-10的列表,实现列表输出,单数在左边,双数在右边。
[C language] Detailed explanation of operators
Exsl file preview, word file preview web page method
聚变云原生,赋能新里程 | 2022开放原子全球开源峰会云原生分论坛圆满召开
MATLAB/Simulink&&STM32CubeMX工具链完成基于模型的设计开发(MBD)(三)