news 2026/4/23 15:25:34

MySQL,InnoDB的auto-inc自增列,据说是表锁?(第6讲,长文收藏)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL,InnoDB的auto-inc自增列,据说是表锁?(第6讲,长文收藏)

《数据库架构100讲》

6. MySQL InnoDB锁:自增锁

今天介绍InnoDB七种锁的第一种:自增锁(Auto-inc Locks)。

一,案例说明

MySQL,InnoDB,默认的隔离级别(RR),假设有数据表:

t(id AUTO_INCREMENT, name);

数据表中有数据:

1, shenjian

2, zhangsan

3, lisi

事务A执行,还未提交

insert into t(name) values(xxx);

事务B执行:

insert into t(name) values(ooo);

问:事务B会不会被阻塞?

二,案例分析

InnoDB在RR隔离级别下,能解决幻读问题,上面这个案例中:

(1)事务A先执行insert,会得到一条(4, xxx)的记录,由于是自增列,故不用显示指定id为4,InnoDB会自动增长,注意此时事务并未提交;

(2)事务B后执行insert,假设不会被阻塞,那会得到一条(5, ooo)的记录;

此时,并未有什么不妥,但如果,

(3)事务A继续insert:

insert into t(name) values(xxoo);

会得到一条(6, xxoo)的记录。

(4)事务A再select:

select * from t where id>3;

得到的结果是:

4, xxx

6, xxoo

画外音:不可能查询到5的记录,在RR的隔离级别下,不可能读取到还未提交事务生成的数据。

咦,这对于事务A来说,就很奇怪了,对于AUTO_INCREMENT的列,连续插入了两条记录,一条是4,接下来一条变成了6,就像莫名其妙的幻影。

三,自增锁(Auto-inc Locks)

自增锁是一种特殊的表级别锁(table-level lock),专门针对事务插入AUTO_INCREMENT类型的列。最简单的情况,如果一个事务正在往表中插入记录,所有其他事务的插入必须等待,以便第一个事务插入的行,是连续的主键值。

画外音,官网是这么说的:

An AUTO-INC lock is a special table-level lock taken by transactions inserting into tables with AUTO_INCREMENT columns. In the simplest case, if one transaction is inserting values into the table, any other transactions must wait to do their own inserts into that table, so that rows inserted by the first transaction receive consecutive primary key values.

与此同时,InnoDB提供了innodb_autoinc_lock_mode配置,可以调节与改变该锁的模式与行为。

四,假如不是自增列

上面的案例,假设不是自增列,又会是什么样的情形呢?

t(id unique PK, name);

数据表中有数据:

10, shenjian

20, zhangsan

30, lisi

事务A执行,在10与20两条记录中插入了一行,还未提交

insert into t values(11, xxx);

事务B执行,也在10与20两条记录中插入了一行:

insert into t values(12, ooo);

这里,便不再使用自增锁,那:

(1)会使用什么锁?

(2)事务B会不会被阻塞呢?

知其然,知其所以然。

思路比结论更重要。

画外音:我学的MySQL知识基于5.6。

==全文完==

有架构合集吗?

《流量从10万到10亿,80个架构问题》

《关于即时通讯架构的一切!》

直播:每天只有30分钟,做什么副业合适?欢迎预约!

最近做了一个新产品:

70天,每天30分钟,短视频行动营(第二曲线最佳选择)

欢迎感兴趣的同学一起参与!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:32:54

DeepSeek-V2.5:全能语言模型实战指南

DeepSeek-V2.5:全能语言模型实战指南 在大模型时代,一个稳定、高效且开箱即用的开发环境,往往决定了从实验到落地的速度。面对像 DeepSeek-V2.5 这样参数量超百亿的先进语言模型,手动配置 PyTorch、CUDA 和各类依赖不仅耗时费力&a…

作者头像 李华
网站建设 2026/4/23 12:31:26

IDEA 高手必备:一招定位并解决 Maven 依赖冲突

来自:https://blog.csdn.net/qq_46548855推荐一个程序员编程资料站:http://cxyroad.com副业赚钱专栏:https://xbt100.top2024年IDEA最新激活方法后台回复:激活码CSDN免登录复制代码插件下载:CSDN复制插件以下是正文。目…

作者头像 李华
网站建设 2026/4/23 13:54:55

QMK固件管理终极指南:从混乱到有序的完整解决方案

QMK固件管理终极指南:从混乱到有序的完整解决方案 【免费下载链接】qmk_firmware Open-source keyboard firmware for Atmel AVR and Arm USB families 项目地址: https://gitcode.com/GitHub_Trending/qm/qmk_firmware 你是否曾经因为键盘固件版本冲突而丢失…

作者头像 李华
网站建设 2026/4/23 11:21:16

JAVA七大设计模式——单例模式

所谓单例模式就是保证程序运行过程中,一个对象最多只有一个实例。具体实现:public class SingletonMode {private static SingletonMode singletonModenull;//私有构造方法,防止外部实例化private SingletonMode(){}/*** Description 获取单例…

作者头像 李华
网站建设 2026/4/23 11:21:58

人机协同智能体的测试指标与评价方法

人机协同智能体的测试指标与评价方法需结合技术性能与业务价值,构建多维度、动态迭代的评估体系。一、核心测试指标任务执行有效性任务成功率:目标达成比例(如指令完成率、问题解决率)自动化完成率:无需人工干预的任务…

作者头像 李华
网站建设 2026/4/23 13:02:48

构建高效机器学习特征工程系统的终极指南

构建高效机器学习特征工程系统的终极指南 【免费下载链接】featuretools 项目地址: https://gitcode.com/gh_mirrors/fea/featuretools 在当今数据驱动的业务环境中,特征工程已成为机器学习项目成功的关键瓶颈。传统的手工特征开发方式不仅耗时费力&#xf…

作者头像 李华