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

一 : insert or update 

前段时间遇到一个问题  
需求如下:    一张表中有几个联合唯一索引  如果索引不存在  则插入    存在则更新

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

连接如下 https://my.oschina.net/hccake/blog/734793


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


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

  112405_13DC_2848957.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方法   更新的字段和值  在末尾追加

112127_Qox4_2848957.png

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

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

112431_KhDq_2848957.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 方法是 根据唯一键值做判断   如果存在  则先删除  再插入

112944_OedO_2848957.png

执行完sql后

113111_n5vg_2848957.png

113104_OCf9_2848957.png

改语句先将原表中113200_FoIg_2848957.png 记录删除 后插入113206_JnFU_2848957.png

再将113223_luKT_2848957.png删除  插入  113230_4ehy_2848957.png

最后由于113334_Bfc4_2848957.png 中  联合唯一索引重复 

又将刚才插入的113206_JnFU_2848957.png  删除  插入  113406_opcV_2848957.png

 

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

 

 

 

转载于:https://my.oschina.net/hccake/blog/777225

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值