MySQL事务隔离级别
事务有 ACID 四个基本属性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability) 数据库事务(简称:事务)是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。—— 维基百科 事务的概念看上去不难,但是需要注意以下几个点: 1、首先,事务就是要保证一组数据库操作,要么全部成功,要么全部失败; 2、在 MySQL 中,事务支持是在 引擎层 实现的; 3、并不是所有引擎都支持事务,如 MyISAM 就不支持,InnoDB 就支持; 今天,我们的主角是 隔离性 ,隔离性是指当多个用户并发操作数据库时,数据库为每一个用户开启不同的事务,这些事务之间相互不干扰,相互隔离。 脏读 脏读(dirty read),简单来说,就是一个事务在处理过程中读取了另外一个事务未提交的数据。这种未提交的数据我们称之为脏数据。依据脏数据所做的操作肯能是不正确的。 不可重复读 不可重复读(non-repeatable read), 是指一个事务范围内,多次查询某个数据,却得到不同的结果 。 在第一个事务中的两次读取数据之间,由于第二个事务的修改, 第一个事务两次读到的数据可能就是不一样的。 脏读和不可重复读的区别: 脏读 是某一事务 读取了 另外一个事务 未提交 的数据, 不可重复读