博客
关于我
mysql 存在update不存在insert
阅读量:793 次
发布时间:2023-02-10

本文共 1024 字,大约阅读时间需要 3 分钟。

MySQL INSERT ON DUPLICATE KEY UPDATE 优化技巧

在数据库开发中,当我们需要判断记录是否存在时,通常会采用两种方式:一种是通过检查记录是否存在再进行操作,另一种则是直接插入,并通过特殊语法处理重复键的情况。后者在性能上更优越,尤其是在高并发场景下。

1. 基础概念解析

MySQL 提供了一种高效的插入语法,可以在插入操作时检查是否存在唯一键或主键。如果存在,则执行更新操作;如果不存在,则插入新记录。这种语法在数据库设计中非常有用,特别是在需要确保数据唯一性的场景中。

语法格式如下:

INSERT INTO table_name(col1, col2, ...) VALUES (value1, value2, ...) ON DUPLICATE KEY UPDATE col1 = col1 + 1;

2. 使用场景

2.1 单插入记录

假设 a 列是主键或拥有唯一索引,且当前值为 1。以下两个语句效果相同:

  • 插入新记录:
  • INSERT INTO test(a, c) VALUES (1, 3) ON DUPLICATE KEY UPDATE c = c + 1;
    1. 直接更新记录:
    2. UPDATE TABLE SET c = c + 1 WHERE a = 1;

      执行后,c 值会根据情况增加。若插入新记录,c 为 1;若更新已有记录,c 为 2。

      2.2 多插入记录

      当插入多行记录时,同样可以使用该语法。例如:

      INSERT INTO test(a, c) VALUES (1, 3), (1, 7) ON DUPLICATE KEY UPDATE c = VALUES(c);

      执行后,c 值会取重复的值。例如,若第一条记录插入成功,第二条记录 c 为 7,结果 c 为 7。

      3. 注意事项

      • 数据库性能:对于数据量较大的表,请谨慎使用该语法。
      • 唯一性约束:必须确保主键或唯一索引列在插入前已建立。
      • 插入顺序:建议按升序或降序插入数据,提升性能表现。

      4. 适用场景

      该语法适用于需要判断记录是否存在的场景。例如:

      • 用户注册时,检查用户名是否已存在。
      • 订单系统中检查订单是否存在。
      • stock 模型中检查库存是否已存在。

      通过合理使用 INSERT ON DUPLICATE KEY UPDATE,可以显著提升数据库操作的效率和用户体验。

      如果需要了解更多数据库优化技巧,或有具体问题,请随时联系我。

    转载地址:http://akbfk.baihongyu.com/

    你可能感兴趣的文章
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询数据库所有表的字段信息
    查看>>
    【Java基础】什么是面向对象?
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 添加列,修改列,删除列
    查看>>
    mysql 添加索引
    查看>>
    MySQL 添加索引,删除索引及其用法
    查看>>
    mysql 状态检查,备份,修复
    查看>>
    MySQL 用 limit 为什么会影响性能?
    查看>>