mysql批量insert bug_mysql 批量插入更新数据 的 两种方法

一 : insert or update

前段时间遇到一个问题

需求如下:    一张表中有几个联合唯一索引  如果索引不存在  则插入    存在则更新

查了资料后 采用了mysql  的insert or update方法

但是当时我并没有理解   其实insert or update 方法是支持批量动态更新的:

现在有  一张表  test   a,b 字段是联合唯一索引

1aea24a910d69d4ab350281102e701df.png

insert into test (a,b,num) values('a','a',3),('b','b',5) on duplicate key update num=num+values(num)

此条sql 前半部分和  批量insert 相同

on duplicate key  关键字 标识  如果该表中有UNIQUE索引或PRIMARY KEY 主键  重复的情况下 导致插入失败  会自动执行update方法   更新的字段和值  在末尾追加

4d4d947fc0ecfb036c485627ac809226.png

中  num+values(num) 中 num是 表中已存在记录的数量   values(num)  则是取的批量更新时 每次待更新的 记录中num的数据

比如上述 sql执行完  的 值如下

6eb79cd6c8d6890909798c849b92dc25.png

num = 原记录值 +  新记录值

ps:如需 更新值写死 也可以写成 num = num + 1

或者 直接更新为带插入数据的  num值   num = values(num)

二:采用replace  实现

replace into test (a,b,num) values('a','a',2),('b','b',3),('a','a',10)

但是replace 方法是 根据唯一键值做判断   如果存在  则先删除  再插入

cc617bfc8b239db3a22f4fa88941d504.png

执行完sql后

93fb12b1e977346c41a826768df0b6a6.png

5d65c3601e8fcc6480a70eb9972dd062.png

改语句先将原表中

908c10eeab501830b95e073b9a8d2413.png 记录删除 后插入

20f5ebfe9df44efc153e04bb7829bc6d.png

再将

44072ef92948cc7a8503536e11f08a37.png删除  插入  

81b256d129a8b76ad5dc95ec3961284d.png

最后由于

6d18833ebd01d755e395a14b2706a710.png 中  联合唯一索引重复

又将刚才插入的

20f5ebfe9df44efc153e04bb7829bc6d.png  删除  插入  

dc99aa26d76e7b49db174a6765d50c76.png

具体实现代码是 需要采用哪种方法  还是要根据项目需求来分析

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值