每天一个开发小知识。
在讨论 MySQL 事务隔离级别之前,我们先来明确 MySQL 中几个数据不一致的概念。
脏读
一个事务读到另一个事务未提交的数据。
不可重复读
由于另一个事务多次提交对数据的修改,导致同一个事务中多次读取同一行数据时,得到的数据不一致。
幻读
由于另一个事务多次提交对数据的新增/删除,导致同一个事务中多次读取同一范围内的数据时,得到的数据不一致。
为解决上面的数据读取问题,MySQL 提供了4个隔离级别。
读未提交
该隔离级别下,一个事务可以读到另一个事务未提交的数据。
该隔离级别下存在脏读,不可重复读,幻读问题。
读已提交
该隔离级别下,一个事务只能读取另一个事务已经提交的数据。
该隔离级别解决了脏读问题,但存在不可重复读,幻读问题。
可重复读
MySQL 通过 MVCC(多版本并发控制),确保每个事务不会出现不可重复读问题。
该隔离级别解决了脏读,不可重复问题,但存在幻读问题。
该隔离级别为 MySQL 的默认隔离级别。
可串行化
MySQL 通过给每条 select 语句加上一把读共享锁,使得该事务未结束之前,其它事务不能修改相关数据,从而解决幻读问题。
该隔离级别解决了脏读,不可重复问题,幻读问题。
每天一个开发小知识,今天你学废了吗?
文章转载自每天一个开发小知识,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
3151次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
876次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
522次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
449次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
381次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
328次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
294次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
291次阅读
2025-05-06 14:40:00
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
280次阅读
2025-04-30 12:17:54
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
277次阅读
2025-04-28 11:01:25