事务隔离级别学习

事务隔离级别

什么是事务

在了解事务隔离级别之前,让我们先来看一下什么是事务。

事务是逻辑上的一组操作,这组操作要么全做要么全不做。

事务的特性

事务的ACID特性

  1. 原子性: 事务是最小的执行单位,不允许分割。事务的原子性确保动作要么全部完成,要么完全不起作用;
  2. 一致性: 执行事务前后,数据保持一致,例如转账业务中,无论事务是否成功,转账者和收款人的总额应该是不变的;
  3. 隔离性: 并发访问数据库时,一个用户的事务不被其他事务所干扰,各并发事务之间数据库是独立的;
  4. 持久性: 一个事务被提交之后。它对数据库中数据的改变是持久的,即使数据库发生故障也不应该对其有任何影响。

并发下的事务

当多个事务并发运行时会出现一些问题

  1. 脏读 : 指一个事务操作完数据后并为提交,但是另一个事务访问到了操作后的数据并且进行了使用,那么这个数据就是所谓的“脏数据”
  2. 修改丢失 : 指一个事务操作数据并对数据进行了修改。与此同时另一个事务也对这个数据进行了修改,这样第一个事务的修改就丢失了
  3. 不可重复读 : 指一个事务访问数据并进行操作时,另一个事务对数据进行了修改,第一个事务再次读这个数据时发现数据与第一次不同,出现了一个事务内两次读同一数据但不一样的情况
  4. 幻读 : 指一个事务在读取了一些数据后,另一个事务又插入了一些数据,随后第一个事务会发现多了一些之前原本不存在的记录

事务隔离级别

SQL标准定义事务的隔离级别有四种

  • READ-UNCOMMITTED(读取未提交): 最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读、幻读或不可重复读
  • READ-COMMITTED(读取已提交): 允许读取并发事务已经提交的数据,可以阻止脏读,但是幻读或不可重复读仍有可能发生
  • REPEATABLE-READ(可重复读): 对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但幻读仍有可能发生
  • SERIALIZABLE(可串行化): 最高的隔离级别,完全服从ACID的隔离级别。所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读

MySQL InnoDB 存储引擎的默认支持的隔离级别是 REPEATABLE-READ(可重读)。我们可以通过SELECT @@tx_isolation;命令来查看,MySQL 8.0 该命令改为SELECT @@transaction_isolation;

可以通过加锁读Next-Key Lock 算法来保证不会产生幻读

隔离级别越低,事务请求的锁越少,所以大部分数据库系统的隔离级别都是读取已提交

学习资料

事务隔离级别(图文详解) | JavaGuide

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值