Mysql on duplicate key update用法及优缺点

1️⃣ 概念

  • ON DUPLICATE KEY UPDATE 是 MySQL 提供的一种 插入或更新冲突处理语法

  • 作用:

    • 当插入记录违反 唯一索引或主键约束 时,执行 UPDATE 操作,而不是报错
  • 类似 UPSERT(插入或更新)


2️⃣ 基本语法

INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...)
ON DUPLICATE KEY UPDATE
column1 = value1, column2 = value2, ...;
  • 说明

    • table_name:表名
    • (column1, column2, ...):插入字段
    • VALUES(value1, value2, ...):对应插入值
    • ON DUPLICATE KEY UPDATE:如果主键或唯一索引冲突,则更新指定列

3️⃣ 示例

示例表

CREATE TABLE users (
``id INT PRIMARY KEY,
``username VARCHAR(50) UNIQUE,
``score INT
);

示例 1:插入或更新单条记录

INSERT INTO users (id, username, score)
VALUES (1, 'Alice', 100)
ON DUPLICATE KEY UPDATE score = 100;
  • 如果 id=1 已存在 → 更新 score=100
  • 如果不存在 → 插入新记录

示例 2:使用 VALUES() 引用插入值

INSERT INTO users (id, username, score)
VALUES (1, 'Alice', 100)
ON DUPLICATE KEY UPDATE score = VALUES(score);
  • VALUES(score):引用插入语句中的 score
  • 优点:无需手动重复写插入值,方便批量操作

示例 3:增加累加逻辑

INSERT INTO users (id, username, score)
VALUES (1, 'Alice', 10)
ON DUPLICATE KEY UPDATE score = score + VALUES(score);
  • 如果记录存在 → score 累加
  • 如果记录不存在 → 插入新记录

4️⃣ 使用场景

  1. 数据统计/计数

    • 累加访问量、点赞数、库存数量
  2. 去重插入

    • 避免重复插入已有唯一键的记录
  3. 同步数据

    • 从外部数据源更新表,已有记录更新,不存在插入

5️⃣ 优点

优点 说明
简化操作 不用先查询再决定插入或更新
支持批量 批量插入可同时处理冲突
高效 单条 SQL 原子操作,减少网络往返
灵活 可对特定字段更新或累加

6️⃣ 缺点/注意事项

缺点/注意事项 说明
仅限唯一键冲突 只有主键或唯一索引冲突才会触发
MySQL 特性 仅适用于 MySQL,不通用标准 SQL
触发器注意 更新触发器可能重复触发
大量写入性能 大批量 UPSERT 可能造成索引碎片或性能下降
VALUES() 被弃用 MySQL 8.0.19 之后推荐使用 INSERT...AS new VALUES...NEW 替代 VALUES()

7️⃣ 高级用法

  • 多字段冲突处理
INSERT INTO products (id, name, stock)
VALUES (1, 'item1', 10)
ON DUPLICATE KEY UPDATE stock = stock + VALUES(stock), name = VALUES(name);
  • 结合事务使用:保证插入/更新操作的原子性

💡 总结

  • ON DUPLICATE KEY UPDATE = 插入或更新冲突处理
  • 优点:原子性、简洁、可批量操作
  • 缺点:仅针对主键/唯一键冲突,MySQL 特有,批量高频写入需注意性能

www.52runoob.com/archives/64...

相关推荐
疯狂的程序猴2 分钟前
iOS App 混淆的真实世界指南,从构建到成品 IPA 的安全链路重塑
后端
bcbnb13 分钟前
iOS 性能测试的工程化方法,构建从底层诊断到真机监控的多工具测试体系
后端
开心就好202516 分钟前
iOS 上架 TestFlight 的真实流程复盘 从构建、上传到审核的团队协作方式
后端
小周在成长25 分钟前
Java 泛型支持的类型
后端
aiopencode25 分钟前
Charles 抓不到包怎么办?HTTPS 抓包失败、TCP 数据流异常与底层补抓方案全解析
后端
稚辉君.MCA_P8_Java30 分钟前
Gemini永久会员 C++返回最长有效子串长度
开发语言·数据结构·c++·后端·算法
Penge6661 小时前
Redis-bgsave浅析
redis·后端
阿白的白日梦1 小时前
Windows下c/c++编译器MinGW-w64下载和安装
c语言·后端
Lear1 小时前
【SpringBoot】 文件下载功能完整实现指南
后端
用户2345267009821 小时前
Python中如何实现数据库连接池深度好文
后端