主页 > 知识库 > MySQL数据库事务隔离级别详解

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

热门标签:服务外包 地方门户网站 Linux服务器 呼叫中心市场需求 AI电销 铁路电话系统 百度竞价排名 网站排名优化

数据库事务隔离级别

数据库事务的隔离级别有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中Innodb的事务隔离级别和锁的关系的讲解教程
  • 关于Mysql隔离级别、锁与MVCC介绍
  • mysql的事务,隔离级别和锁用法实例分析
  • 深入理解Mysql的四种隔离级别
  • MySQL 四种事务隔离级别详解及对比
  • MySQL四种事务隔离级别详解
  • Mysql事务隔离级别之读提交详解
  • MySQL隔离级别和锁机制的深入讲解

标签:衡水 兰州 湘潭 仙桃 湖南 崇左 铜川 黄山

巨人网络通讯声明:本文标题《MySQL数据库事务隔离级别详解》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266