当前位置: 首页 > news >正文

ON DUPLICATE KEY UPDATE 导致自增ID跳跃式增长

1. 语法

INSERT INTO table_name VALUES(null,param,..) ON DUPLICATE KEY UPDATE param_name = VALUES(param_name);

2. 介绍

ON DUPLICATE KEY UPDATE 会根据主键或唯一索引检索当前记录是否已经存在,存在更新,不存在插入;
优先级:主键 > 唯一索引

  • 当主键重复时,更新UPDATE后面的字段值,不重复插入新数据;
  • 当主键不重复,唯一索引重复时,更新UPDATE后面的字段值,不重复插入新数据;
  • 当表中不存在索引重复时,直接插入;

3. 存在问题

在执行ON DUPLICATE KEY UPDATE会发现,如果存在自增ID,默认情况下每次执行结束后,会发现ID跳跃式增长。

3.1 原因

mysql中的innodb_autoinc_lock_mode参数存在三种模式:0,1,2。

  1. tradition(innodb_autoinc_lock_mode = 0)
    在这个模式下,在insert语句执行的时候,mysql会为当前语句添加auto_inc锁,只有当前语句执行完毕后,才会释放auto_inc锁,这种方法虽然保证了语句在执行过程中的数据安全性,但是在高并发的情况下,会影响效率。
  2. consecutive(innodb_autoinc_lock_mode = 1)默认模式
    在执行批量insert操作的时候,会一次生成多个连续的自增ID值,这也导致了自增ID的跳跃式增长,相比于tradition模式,提高了并发效率。
  3. interleaved(innodb_autoinc_lock_mode = 2)
    在这种模式下,是每执行一个insert语句同时会获得一个自增ID值,同时取消了anto_inc锁,但是不能保证ID连续性。

4. 解决办法

4.1 拆分逻辑

将ON DUPLICATE KEY UPDATE语句从逻辑层面拆分为两步,先执行update操作,如果update操作影响语句为0,则执行insert操作。

4.2 修改

编辑/etc/my.cnf,修改innodb_autoinc_lock_mode=0;

4.3 修改auto_increment值

在ON DUPLICATE KEY UPDATE语句后执行
ALTER TABLE table_name auto_increment=1;,但是每次执行这个语句的时候,都会执行alter语句,会导致效率变低。

具体解决办法根据实际业务场景需要选择。

http://www.lryc.cn/news/198035.html

相关文章:

  • python学习笔记5-堆
  • 【微服务 SpringCloud】实用篇 · Eureka注册中心
  • WebSocket学习笔记
  • centos 内核对应列表 内核升级 linux
  • 如何判断a类b类c类ip地址
  • SNAP对Sentinel-1预处理
  • GEE案例——指定区域纯净森林提取分析(红和近红外波段)阈值法提取森林面积
  • JavaScript从入门到精通系列第二十一篇:JavaScript中的原型对象详解
  • app.json: [“usingComponents“][“van-icon“]: “@vant/weapp/icon/index“ 未找到
  • Kotlin中循环语句
  • Java String之正则表达式
  • Kotlin 协程再探之为什么使用协程反而更慢了?
  • Hadoop3教程(十六):MapReduce中的OutputFormat
  • 通过表查询 sm37 排程运行情况 JOB 数据保存在表TBTCP 和 TBTCO中
  • append_ocr_trainf
  • 小程序原生代码转uniapp
  • 云原生微服务 第五章 Spring Cloud Netflix Eureka集成负载均衡组件Ribbon
  • 七大排序 (9000字详解直接插入排序,希尔排序,选择排序,堆排序,冒泡排序,快速排序,归并排序)
  • 一、nginx配置
  • win32汇编-LEA指令是将一个内存地址加载到一个寄存器中
  • leetcode做题笔记189. 轮转数组
  • 数据库第七章作业
  • 使用服务器训练模型的注意事项
  • Linux性能优化--性能追踪3:系统级迟缓(prelink)
  • SpringBoot2.x简单集成Flowable
  • 微信小程序一键获取位置
  • Linux性能优化--使用性能工具发现问题
  • 【Proteus仿真】【STM32单片机】路灯控制系统
  • Flutter笔记:发布一个Flutter头像模块 easy_avatar
  • 标准化助推开源发展丨九州未来参编开源领域4项团体标准正式发布