0

0

mysql中的事务隔离级别与执行顺序的关系

P粉602998670

P粉602998670

发布时间:2026-01-19 10:04:50

|

813人浏览过

|

来源于php中文网

原创

事务隔离级别决定的是“能看到什么”,而非执行顺序;它通过MVCC快照(read view)控制SELECT可见的数据版本,而执行顺序由锁机制、语句类型及加锁时机决定。

mysql中的事务隔离级别与执行顺序的关系

事务隔离级别决定的是「能看到什么」,不是「执行顺序」

MySQL 的事务隔离级别(READ UNCOMMITTEDREAD COMMITTEDREPEATABLE READSERIALIZABLE)不控制 SQL 语句的执行先后,而是约束一个事务中 SELECT 能读到哪些版本的数据。真正影响执行顺序的是锁机制、MVCC 快照生成时机和语句是否触发加锁(比如 UPDATESELECT ... FOR UPDATE)。

常见误解是:设成 REPEATABLE READ 就能保证两个事务按提交顺序“串行执行”。实际不是——它们仍可并发执行,只是读视图被冻结在事务第一次 SELECT 或开启时,导致“读一致性”,而非“执行一致性”。

不同隔离级别下,同一时间点的 SELECT 结果为何不同

关键在事务开启时获取的 MVCC 快照(read view)范围不同:

  • READ UNCOMMITTED:不创建 read view,SELECT 直接读最新行版本(可能脏读)
  • READ COMMITTED:每次 SELECT 都新建 read view,只能看到已提交的、在本语句开始前已提交的事务修改
  • REPEATABLE READ:事务第一次 SELECT 时创建 read view,后续所有 SELECT 复用它(所以不会出现不可重复读)
  • SERIALIZABLE:隐式为所有 SELECT 加共享锁,强制阻塞写操作,实际变成串行执行

例如两个事务 T1 和 T2 同时运行:

DESTOON B2B网站管理系统
DESTOON B2B网站管理系统

DESTOON B2B网站管理系统是一套完善的B2B(电子商务)行业门户解决方案。系统基于PHP+MySQL开发,采用B/S架构,模板与程序分离,源码开放。模型化的开发思路,可扩展或删除任何功能;创新的缓存技术与数据库设计,可负载千万级别数据容量及访问。

下载
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
START TRANSACTION;
SELECT * FROM t WHERE id = 1; -- 此刻生成 read view
-- 即使 T2 此后更新并提交 id=1 的行,T1 再 SELECT 仍看到旧值

执行顺序受锁和语句类型影响,比隔离级别更直接

即使在 REPEATABLE READ 下,UPDATESELECT ... FOR UPDATE 仍会尝试加行锁或间隙锁,导致阻塞。这时“谁先拿到锁”就决定了实际执行顺序,跟隔离级别无关。

  • INSERT 可能触发插入意向锁,与间隙锁冲突
  • UPDATE t SET x=1 WHERE y=5 在无索引列 y 上会升级为表锁
  • SELECT ... LOCK IN SHARE MODEFOR UPDATE 显式申请锁,立即参与锁竞争

典型现象:事务 A 执行 UPDATE t SET v=1 WHERE id=10 未提交,事务 B 在相同行上执行 UPDATESELECT ... FOR UPDATE 就会被挂起,直到 A 提交或回滚——这个等待链就是真实执行顺序的体现。

容易忽略的关键点:autocommit 和 START TRANSACTION 的时机

MySQL 默认 autocommit = 1,单条 DML(如 UPDATE)会自动成为独立事务。此时隔离级别只作用于该语句本身,没有“跨语句一致性”可言。只有显式 START TRANSACTIONBEGIN 后,才进入多语句事务上下文,隔离级别才有持续效果。

  • 忘记关 autocommit 就直接写多个 UPDATE,误以为它们在一个事务里
  • 在存储过程中调用 START TRANSACTION,但没处理异常回滚,导致连接长期持有锁
  • SET SESSION TRANSACTION ISOLATION LEVEL ... 只对后续事务生效,不影响当前已开启的事务

验证当前事务状态最直接的方式是查:

SELECT @@autocommit, @@transaction_isolation, trx_state 
FROM information_schema.INNODB_TRX 
WHERE trx_mysql_thread_id = CONNECTION_ID();

相关专题

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

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

682

2023.10.12

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

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

320

2023.10.27

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

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

347

2024.02.23

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

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

1095

2024.03.06

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

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

357

2024.03.06

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

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

676

2024.04.07

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

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

575

2024.04.29

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

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

417

2024.04.29

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

36

2026.01.18

热门下载

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

精品课程

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

共48课时 | 1.8万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 801人学习

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

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