MySQL数据库事务隔离级别详解

发布时间 - 2026-01-11 00:11:35    点击率:

数据库事务隔离级别

数据库事务的隔离级别有4个,由低到高依次为

  1. Read uncommitted:允许脏读。
  2. Read committed: 防止脏读,最常用的隔离级别,并且是大多数数据库的默认隔离级别。
  3. Repeatable read:可以防止脏读和不可重复读。
  4. Serializable:可以防止脏读,不可重复读取和幻读,(事务串行化)会降低数据库的效率。

这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。

√: 可能出现 ×: 不会出现

事务级别 脏读 不可重复读 幻读
Read uncommitted
Read committed ×
Repeatable read × ×
Serializable × × ×

注意:我们讨论隔离级别的场景,主要是在多个事务并发的情况下。

脏读、幻读、不可重复读

脏读:

脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。

不可重复读:

是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。(即不能读到相同的数据内容)

幻读:

是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。

example:

表:

CREATE TABLE `cc_wsyw126_user_test_isolation_copy` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `password` varchar(64) NOT NULL,
 `age` int(11) NOT NULL,
 PRIMARY KEY (`id`),
 KEY `ix_age` (`age`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

模拟数据:

INSERT INTO `cc_wsyw126_user_test_isolation_copy` (`password`, `age`) 
VALUES 
('1', 1),
('2', 2),
('3', 3),
('4', 4);

第一个事务A:

start transaction 
insert into cc_wsyw126_user_test_isolation_copy (password, age) values ('5',5)
commit

第二个事务B:

start transaction 
update cc_wsyw126_user_test_isolation_copy set age = 2 where password >='2'
select * from cc_wsyw126_user_test_isolation_copy where password >= '2';
commit

重现步骤:

只要A事务的insert语句,在B事务select之前和update之后即可。

MySQL InnoDB存储引擎,实现的是基于多版本的并发控制协议——MVCC (Multi-Version Concurrency Control) 加上间隙锁(next-key locking)策略在Repeatable Read (RR)隔离级别下不存在幻读。如果测试幻读,在MyISAM下实验。

在聚集索引(主键索引)中,如果有唯一性约束,InnoDB会将默认的next-key lock降级为record lock。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# MySQL数据库事务隔离级别  # MySQL数据库事务详解  # 数据库事务隔离级别  # 深入理解Mysql的四种隔离级别  # MySQL 四种事务隔离级别详解及对比  # MySQL四种事务隔离级别详解  # 浅析MYSQL REPEATABLE-READ隔离级别  # MySQL查看和修改事务隔离级别的实例讲解  # 详解MySQL中事务隔离级别的实现原理  # Mysql事务隔离级别之读提交详解  # 如何修改mysql的隔离级别  # MySQL中隔离级别的4种小结  # 第一个  # 两次  # 第二个  # 读到  # 还没有  # 是指  # 另外一个  # 进行了  # 可以防止  # 的是  # 发生了  # 就会  # 是在  # 在这个  # 多个  # 希望能  # 不存在  # 涉及到  # 谢谢大家  # 会将 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何快速生成高效建站系统源代码?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  JavaScript如何实现音频处理_Web Audio API如何工作?  北京网站制作公司哪家好一点,北京租房网站有哪些?  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  如何用景安虚拟主机手机版绑定域名建站?  如何用美橙互联一键搭建多站合一网站?  北京企业网站设计制作公司,北京铁路集团官方网站?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  Laravel如何使用模型观察者?(Observer代码示例)  javascript中对象的定义、使用以及对象和原型链操作小结  Python文件流缓冲机制_IO性能解析【教程】  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  如何用AWS免费套餐快速搭建高效网站?  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  海南网站制作公司有哪些,海口网是哪家的?  Python进程池调度策略_任务分发说明【指导】  南京网站制作费用,南京远驱官方网站?  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  免费网站制作appp,免费制作app哪个平台好?  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  长沙企业网站制作哪家好,长沙水业集团官方网站?  Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明  php结合redis实现高并发下的抢购、秒杀功能的实例  教你用AI润色文章,让你的文字表达更专业  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  ,网页ppt怎么弄成自己的ppt?  PHP 500报错的快速解决方法  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  高性价比服务器租赁——企业级配置与24小时运维服务  如何在云虚拟主机上快速搭建个人网站?  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  如何快速上传建站程序避免常见错误?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  js实现点击每个li节点,都弹出其文本值及修改