innodb_autoinc_lock_mode 是控制 MySQL 自增 ID 插入时加锁行为的参数,影响并发性能与 ID 连续性;默认值 1 平衡安全与性能,0 已弃用,2 需 ROW 格式 binlog 且跳号不可避免。innodb_autoinc_lock_mode 是什么,为什么改它这个参数控制 MySQL 在插入自增 ID 时的加锁行为,直接影响并发插入性能和 ID 分配的连续性。默认值是 1("连续"模式),但高并发批量插入(比如 INSERT ... SELECT、REPLACE、LOAD DATA)时容易卡住,或出现 ID 跳号------这不是 bug,是设计使然。想让自增 ID 尽量紧凑、减少锁等待?得调它;想吞吐优先、能接受跳号?默认就行。关键是别在没理解场景时盲目设成 0 或 2,否则主从不一致或 binlog 复制失败的风险会立刻浮现。三种取值的实际影响和适用场景0(传统模式):全表级 AUTO_INC 锁,每次插都等,ID 绝对连续,但并发极低。只在老版本兼容或极特殊审计要求下用,现在基本不用。1(默认,连续模式):普通 INSERT 用轻量锁,批量语句(如 INSERT INTO t SELECT ...)仍会预分配一段 ID 并加表锁。平衡了性能和可预测性,主从复制安全(statement-based 和 row-based 都 OK)。2(交错模式):所有插入都不加表锁,ID 分配完全交错,性能最高,但 ID 必然跳号,且 仅支持 row-based binlog 格式。如果 binlog_format 还是 STATEMENT,直接报错 ERROR 1665 (HY000): Cannot execute statement: binlogging impossible。无序列表说明: 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
ServBay1 天前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队用户8356290780511 天前
如何使用 Python 添加和管理 Excel 批注(完整示例)用户8356290780511 天前
使用 Python 管理 Excel 工作表:创建、复制、删除与重命名SelectDB1 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台这个DBA有点耶1 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询掉头发的王富贵1 天前
【StarRocks】极限十分钟入门StarRocksNturmoils1 天前
WHERE 条件别凭习惯写,常用查询先跑一遍荣码1 天前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑用户8356290780512 天前
Python 操作 PDF 附件:添加、查看与管理指南Databend2 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路