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

soゝso 2018-04-17 01:16:43 2247

我们遇到挺多这样的问题,当用户并发提交数据,重复提交数据。导致数据重复,或者  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

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

本文主题:

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

相关文章
最新MyEclipse8.5注册码,有效期到2020年 (已经更新)
JSON格式讲解,JSON获取对象,JSONObject和JSONArray的操作
json 解析与生成工具类 ,JSON操作讲解(附件)
MySql数据库优化注意的四个细节(方法)
MySQL数据库存储过程字符集问题,乱码的解决办法
MySQL数据库为用户设置密码,Mysql修改密码。Mysql忘记密码解决方法
MySQL数据库表怎么锁定
MySQL 分区、分表
Elasticsearch教程(七) elasticsearch Insert 插入数据(Java)
IE、Firefox对同一域名访问并发限制,及解决优化方案
最新文章
ICP怎么操作取消备案,企业、个人怎么自己申请取消备案? 17
Javascript 加密/压缩后运行不了,JavaScript报错排查讲解 41
JavaScript 不可逆加密问题排查之方案一(闭包优化) 45
Java爬虫,Jsoup 爬取大众点评、美团商家信息电话号码解决方案 243
分解质因数 JavaScript 计算方式,及分解质因数讲解 8
湖南腾众4s店服务怎么样?进来看看你就知道了 29
SEO 之 SpringMVC redirect 301,301和302区别详细讲解 82
网站如何设置404页面、500等错误页面,有什么漏洞?怎么预防? 101
Java 文字转图片输出,Java 输出透明背景图片,Java文字转图片防爬虫 153
HttpClient获取访问域名的真实ip,HttpClient请求获取目标IP地址 298
最热文章
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 175183
Elasticsearch教程(四) elasticsearch head 插件安装和使用 138300
我为什么要选择RabbitMQ ,RabbitMQ简介,各种MQ选型对比 117968
Elasticsearch教程(六) elasticsearch Client创建 81987
Elasticsearch教程(一),全程直播(小白级别) 77090
Elasticsearch教程(二),IK分词器安装 77059
Elasticsearch教程(八) elasticsearch delete 删除数据(Java) 76748
苹果电脑Mac怎么恢复出厂系统?苹果系统怎么重装系统? 75165
Elasticsearch教程(五) elasticsearch Mapping的创建 69395
Elasticsearch教程(三),IK分词器安装 (极速版) 58149

骚码加入我们 / 千人QQ群:259217951

入群需要5元,如果没有QQ钱包,可以先Alipay、微信,赞助然后加群主拉进。

二维码生成 来自 >> 二维码生成器

支付扫码

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

正在加载... ...