首页 > 数据库技术 > 详细

mysql使用on duplicate key update批量更新数据

时间:2021-06-30 18:09:51      阅读:13      评论:0      收藏:0      [点我收藏+]

需求:需要导入用户积分数据到积分总表total_score。 当total_score表中存在用户的数据时,直接更新score,update_at字段的值;否则插入一条新用户记录。

以往做法:循环select表中的user记录是否存在,存在则使用update;不存在则使用insert。
做法弊端:每处理一条记录需要操作两次数据库(select、update/insert)

优化做法:使用insert语句搭配 on duplicate key update使用。
做法注意:比如上面的需求,需要用户user唯一,就是total_score表中,每个用户只存在一个记录。给user_id设为unique

实现代码:

      insert into total_score(
            user_id,
            score,
            create_at,
            update_at
      ) values (
            101,
            10,
            now(),
            now()
      ) on duplicate key update score=score+10,update_at=now();

on duplicate key update使用注意事项:
  1. 要注意设置唯一索引;
  2. 不支持与where子句联合使用;
  3. 数据量很大时,不推荐使用。

mysql使用on duplicate key update批量更新数据

原文:https://www.cnblogs.com/luoguixin/p/14954796.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!