news 2026/4/16 15:58:10

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/14 19:32:01

JavaWeb-JDBC事务回滚

什么是JDBC? Java连接数据库!需要jar包支持: java.sqljavax.sqlmysql-connter-java……连接驱动(必须要导入) 实验-Mysql数据库 MySQL数据插入表中数据CREATE TABLE users(id INT PRIMARY KEY,name VARCHAR(40),passwo…

作者头像 李华
网站建设 2026/4/16 12:15:41

终极指南:C语言HTML解析库gumbo-parser的完整使用手册

终极指南:C语言HTML解析库gumbo-parser的完整使用手册 【免费下载链接】gumbo-parser An HTML5 parsing library in pure C99 项目地址: https://gitcode.com/gh_mirrors/gum/gumbo-parser 在C语言开发领域,HTML解析库的选择往往决定了项目的成败…

作者头像 李华
网站建设 2026/4/16 10:51:48

历史研究新范式:AI驱动的智能史料分析方法论

历史研究新范式:AI驱动的智能史料分析方法论 【免费下载链接】Noi 项目地址: https://gitcode.com/GitHub_Trending/no/Noi 在传统历史研究面临信息爆炸与专业壁垒双重挑战的当下,智能史料解读工具通过人工智能技术为研究者提供了全新的分析视角…

作者头像 李华
网站建设 2026/4/16 12:44:43

替代ELK:ClickHouse+Kafka+FlieBeat才是最绝的

来自:推荐一个程序员编程资料站:http://cxyroad.com副业赚钱专栏:https://xbt100.top2024年IDEA最新激活方法后台回复:激活码CSDN免登录复制代码插件下载:CSDN复制插件以下是正文。saas 服务未来会面临数据安全、合规等…

作者头像 李华
网站建设 2026/4/16 15:09:50

JS 工具函数(utils)大全

JS 工具函数(utils)大全 JS 工具函数(utils)是项目中复用率极高的通用函数集合,覆盖类型判断、数据处理、时间格式化、浏览器操作、数组/对象处理等场景,能大幅提升开发效率。以下是高频实用的工具函数&am…

作者头像 李华