0

0

MySQL 事务机制面试题整理

冷炫風刃

冷炫風刃

发布时间:2026-03-05 19:15:11

|

503人浏览过

|

来源于php中文网

原创

事务的四大特性是原子性、一致性、隔离性、持久性;mysql innodb默认隔离级别为可重复读,通过mvcc和间隙锁解决幻读;间隙锁在范围查询或不存在记录的等值查询时触发,死锁可通过统一加锁顺序、缩短事务等避免。

mysql 事务机制面试题整理

事务的四大特性(ACID)是什么

原子性(Atomicity):事务中的所有操作要么全部成功,要么全部失败回滚,不可只执行其中一部分。

一致性(Consistency):事务执行前后,数据库必须从一个合法状态转移到另一个合法状态,满足预定义的约束(如主键、外键、唯一性等)。

隔离性(Isolation):多个事务并发执行时,彼此互不干扰,一个事务的中间状态对其他事务不可见。

持久性(Durability):事务一旦提交,其结果将永久保存在数据库中,即使系统崩溃也不会丢失。

MySQL 默认的隔离级别及常见问题

MySQL InnoDB 默认隔离级别是 可重复读(REPEATABLE READ)

各隔离级别对应的主要问题:

citySHOP多用户商城系统
citySHOP多用户商城系统

citySHOP是一款集CMS、网店、商品、分类信息、论坛等为一体的城市多用户商城系统,已完美整合目前流行的Discuz! 6.0论坛,采用最新的5.0版PHP+MYSQL技术。面向对象的数据库连接机制,缓存及80%静态化处理,使它能最大程度减轻服务器负担,为您节约建设成本。多级店铺区分及联盟商户地图标注,实体店与虚拟完美结合。个性化的店铺系统,会员后台一体化管理。后台登陆初始网站密匙:LOVES

下载
  • 读未提交(READ UNCOMMITTED):可能读到脏数据(未提交的修改),存在脏读、不可重复读、幻读
  • 读已提交(READ COMMITTED):避免脏读,但会出现不可重复读和幻读
  • 可重复读(REPEATABLE READ):避免脏读和不可重复读;InnoDB 通过多版本并发控制(MVCC)+间隙锁(Gap Lock)基本解决幻读(快照读不幻读,当前读仍可能幻读)
  • 串行化(SERIALIZABLE):最高隔离级别,强制事务串行执行,完全避免脏读、不可重复读、幻读,但性能最差

什么是 MVCC?InnoDB 如何实现可重复读

MVCC(Multi-Version Concurrency Control)即多版本并发控制,是 InnoDB 实现高并发下非阻塞读的关键机制。

核心要素包括:

  • 每行记录包含两个隐藏字段:DB_TRX_ID(最后修改该行的事务 ID)和 DB_ROLL_PTR(指向 undo log 中前一版本的指针)
  • 事务启动时会生成一个唯一的 Read View,记录当前活跃事务 ID 列表、最小/最大事务 ID 等信息
  • 查询时根据 Read View 判断哪些版本对当前事务可见:仅当行版本的 trx_id 小于事务启动时的 min_trx_id,或属于已提交事务且不在活跃列表中,才可见

因此,在可重复读下,同一事务内多次普通 SELECT(快照读)看到的是事务开始时的一致快照,不会受其他事务提交影响。

什么情况下会触发间隙锁?如何避免死锁

间隙锁(Gap Lock)用于防止其他事务在索引间隙中插入新记录,主要出现在 范围查询(如 WHERE id BETWEEN 10 AND 20)唯一索引等值查询但记录不存在时(如 UPDATE t SET x=1 WHERE id = 15,而 id=15 不存在)。

死锁常见诱因与规避建议:

  • 多个事务以不同顺序加锁访问相同资源(如事务 A 先锁 id=1 再锁 id=2,事务 B 反之)→ 建议统一 SQL 执行顺序,按主键升序更新
  • 长事务持有锁时间过久 → 缩短事务粒度,避免在事务中做耗时操作(如调用外部接口、大循环)
  • 未使用索引导致全表扫描加锁 → 确保 WHERE 条件走索引,避免锁升级
  • 高频竞争热点行 → 考虑分片、缓存、或应用层限流重试

可通过 SHOW ENGINE INNODB STATUS 查看最近死锁详情,定位冲突 SQL 和锁类型。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1090

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2028

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1581

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

438

2024.04.29

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 844人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号