Mysql 并发插入、存在不插入,存在更新操作

JSON 2018-04-17 01:16:43 12928

我们遇到挺多这样的问题,当用户并发提交数据,重复提交数据。导致数据重复,或者  Mysql     SQL  报错。

几种解决办法,对应到几种业务场景。

方案一,先查再插

这个应该是最常见的处理方式,是醉不安全的,因为一旦有并发其实完全防止不了,来看看伪代码。

Entity entity = service.findById(10);
if(null == entity){
    service.insert(obj);
}else{
    service.update(obj);
}

先根据条件查询,存在就更新,不存在添加,但是往往我们是集群、多列的状态下,会再你正在判断null == entity的时候,另外一个线程已经插入完毕了,导致你以为是不存在,重复插入。

方案二,存在即更新,不存在即插入

我们平常的INSERT INTO   SQL  是这么写:

INSERT INTO demo_in(a,b,c)  VALUES(123, 2, 4);

比如C是主键,插入2次就会抛出异常:

[23000][1062] Duplicate entry '4' for key 'PRIMARY'

所以我们用到REPLACE关键字,他的作用如题,存在即更新,不存在即插入,和delete + Insert Into 一样。但是它一个原子操作,是一步完成,所以我们不用担心有其他问题的出现,但是使用REPLACE的时候,一定要保证表有唯一主键。

重要:执行REPLACE 语句后,系统返回了所影响的行数,如果返回1,说明在表中并没有重复的记录,如果返回2,说明有一条重复记录,系统自动先调用了DELETE删除这条记录,然后再记录用INSERT来插入这条记录。

 改造一下上面的语句就是:

REPLACE INTO demo_in(a,b,c)  VALUES(123, 2, 4);

方案三,存在不插入,不存在再插入

这个其实很简单,因为  Mysql  不能做到插入的时候带where条件,故用了一张临时表来处理。

INSERT INTO demo_in(a,b,c) SELECT 123, 2, 4 FROM DUAL WHERE NOT EXISTS(SELECT c FROM demo_in WHERE c = 4);

用临时表DUAL来标记数据,然后插入到demo_in表中。条件是c=4,并且not exists,也就是当c=4条件满足,则不插入。


版权所属:SO JSON在线解析

原文地址:https://www.sojson.com/blog/288.html

转载时必须以链接形式注明原始出处及本声明。

本文主题:

如果本文对你有帮助,那么请你赞助我,让我更有激情的写下去,帮助更多的人。

关于作者
一个低调而闷骚的男人。
相关文章
最新文章
当我谈 HTTP 时,我谈些什么? 6577
新浪短链(t.cn)最新申请官方API的方法讲解。 30651
QUIC / HTTP3 协议详细分析讲解 3265
恭喜那个做云存储的七牛云完成 F 轮 10 亿人民币的融资,开启新的云旅程 4729
Autojs怎么安全加密?Autojs在线加密工具注意事项。 12869
Java JSON 组件选型之 FastJson 为什么总有漏洞? 31746
使用七牛云存储实现图片API,自动删除图片方案合集 4867
神速ICP备案经验分享,ICP备案居然一天就通过了 6183
百度加强推送URL链接,百度SEO强行推送链接JavaScript代码案例讲解。 5992
SOJSON 拓展服务器被DDos攻击了一晚上,是如何解决的? 7826
最热文章
苹果电脑Mac怎么恢复出厂系统?苹果系统怎么重装系统? 529605
最新MyEclipse8.5注册码,有效期到2020年 (已经更新) 454475
我为什么要选择RabbitMQ ,RabbitMQ简介,各种MQ选型对比 453568
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 405689
Elasticsearch教程(四) elasticsearch head 插件安装和使用 288975
Jackson 时间格式化,时间注解 @JsonFormat 用法、时差问题说明 266491
谈谈斐讯路由器劫持,你用斐讯路由器,你需要知道的事情 168421
Elasticsearch教程(一),全程直播(小白级别) 145031
Java 信任所有SSL证书,HTTPS请求抛错,忽略证书请求完美解决 141404
Elasticsearch教程(五) elasticsearch Mapping的创建 112561
支付扫码

所有赞助/开支都讲公开明细,用于网站维护:赞助名单查看

查看我的收藏

正在加载... ...