0

0

mysql中脏读不可重复读幻读是什么_mysql事务问题讲解

P粉602998670

P粉602998670

发布时间:2025-12-16 20:07:35

|

468人浏览过

|

来源于php中文网

原创

脏读、不可重复读和幻读是MySQL并发事务中因隔离级别不足导致的三类数据不一致问题:脏读指读取未提交数据;不可重复读指同一行两次读取结果不同;幻读指相同条件查询返回行数变化。

mysql中脏读不可重复读幻读是什么_mysql事务问题讲解

脏读、不可重复读和幻读,是 MySQL 多事务并发时因隔离级别不足引发的三类典型数据不一致问题。它们本质都是“一个事务看到了另一个事务不该让它看到的状态”,区别在于看到的是什么、什么时候看到、以及影响范围。

脏读:读到了别人还没定论的数据

事务 A 修改了一行数据但尚未提交,事务 B 此时读取了这行被修改后的值;如果随后 A 回滚,B 读到的就是一条根本不存在的“假数据”。这就是脏读。

例如:

  • A 执行 UPDATE account SET balance = 50 WHERE id = 1;(未 COMMIT)
  • B 执行 SELECT balance FROM account WHERE id = 1;,查到 balance = 50
  • A 突然 ROLLBACK,balance 实际仍是 100
  • B 已基于错误的 50 做了后续计算——结果出错

脏读只在 READ UNCOMMITTED 隔离级别下发生,MySQL 默认不启用该级别。

不可重复读:同一行数据,两次读不一样

事务 A 在同一个事务内两次读取同一行记录,中间事务 B 修改并提交了该行,导致 A 第二次读到的是新值。重点是“同一行被改了”。

例如:

  • A 第一次 SELECT status FROM order WHERE id = 1001; → 返回 'pending'
  • B 执行 UPDATE order SET status = 'shipped' WHERE id = 1001; COMMIT;
  • A 再次执行相同 SELECT → 返回 'shipped'

这种“读-写-再读”的不一致,在 READ COMMITTED 级别仍可能发生,但 REPEATABLE READ(MySQL 默认)通过 MVCC 机制避免了它。

Flex3组件和框架的生命周期 中文WORD版
Flex3组件和框架的生命周期 中文WORD版

在整本书中我们所涉及许多的Flex框架源码,但为了简洁,我们不总是显示所指的代码。当你阅读这本书时,要求你打开Flex Builder,或能够访问Flex3框架的源码,跟随着我们所讨论源码是怎么工作及为什么这样做。 如果你跟着阅读源码,请注意,我们经常跳过功能或者具体的代码,以便我们可以对应当前的主题。这样能防止我们远离当前的主题,主要是讲解代码的微妙之处。这并不是说那些代码的作用不重要,而是那些代码处理特别的案例,防止潜在的错误或在生命周期的后面来处理,只是我们当前没有讨论它。有需要的朋友可以下载看看

下载

幻读:同一条件查询,结果集行数变了

事务 A 按条件做范围查询(如 WHERE amount > 100),事务 B 在此期间插入或删除了符合该条件的新行并提交,A 再次查询时发现多了一条或少了一条——就像凭空出现或消失的“幻影”。

例如:

  • A 查询 SELECT * FROM payment WHERE created_at > '2025-12-01'; 得到 12 条
  • B 插入一条满足条件的新记录并 COMMIT
  • A 再次执行相同查询 → 得到 13 条

注意:幻读不是某一行内容变了,而是“符合条件的行集合”发生了变化。MySQL 的 REPEATABLE READ 能防止大部分幻读(靠间隙锁+Next-Key Lock),但严格意义上的幻读(如 INSERT 后立刻 SELECT FOR UPDATE)在某些场景仍存在,SERIALIZABLE 才能彻底杜绝。

怎么选隔离级别?

MySQL 四个级别逐级增强,也逐级牺牲并发性能:

  • READ UNCOMMITTED:不推荐,脏读风险高
  • READ COMMITTED:避免脏读,适合日志类、统计类对一致性要求不严的场景
  • REPEATABLE READ:MySQL 默认,兼顾一致性与性能,覆盖绝大多数业务(如订单、账户操作)
  • SERIALIZABLE:加锁最重,事务串行执行,几乎无并发,仅用于极敏感且低频的核心校验

实际项目中,90% 以上用 REPEATABLE READ 即可,关键逻辑可通过显式加锁(如 SELECT ... FOR UPDATE)或应用层幂等设计进一步兜底。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

669

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

308

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

282

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

517

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

258

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

387

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

536

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

610

2023.08.14

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.05

热门下载

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

精品课程

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

共48课时 | 2.1万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 823人学习

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

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