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

需求:需要导入用户积分数据到积分总表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. 数据量很大时,不推荐使用。
posted @   米饭!大米饭  阅读(1316)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示