简述MySQL事务的特性以及隔离级别

事务是数据库操作的逻辑执行单元,具备原子性、一致性、隔离性和持久性四大特性。原子性确保操作全部完成或全部不完成;一致性保证数据库状态从一个一致性转换到另一个;隔离性防止并发事务相互干扰;持久性则确保事务提交后的变更持久保存。事务的隔离级别有读未提交、读已提交、可重复读和串行化,不同级别解决不同程度的并发问题,如脏读、不可重复读和幻读。设置合适的隔离级别可以有效管理并发事务中的数据一致性。
摘要由CSDN通过智能技术生成

1、什么是事务

        事务就是由N步数据库操作序列组成的逻辑执行单元,这系列操作要么全部执行,要么全部放弃执行。当在数据库中更改数据成功时,在事务中更改的数据便会提交,不再改变。否则,事务就取消或者回滚,更改无效。

2、事务的特性

        简单介绍一下事务的特性(ACID分别指的是原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。


  • 原子性事务开始后所有操作,要么全部完成,要么全部不完成,不可能停滞在中间环节。事务执行过程中出错,会回滚(Rollback)到事务开始前的状态,所有的操作就像没有发生一样。

解释:原子性顾名思义就像化学中学过的原子,是物质构成的基本单位,也就是说事务是一个不可分割的整体,是应用中不可再分的最小执行体


  • 一致性事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态

解释:当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。比如张三向李四转账,不可能张三扣了钱,李四却没收到。


  • 隔离性一个事务的执行不能对其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰

解释:同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰。比如张三正在从一张银行卡中取钱,在张三取钱的过程结束前,李四不能向这张卡转账


  • 持久性事务完成后,该事务所对数据库所作的更改将被保存到数据库之中,不能回滚

解释:持久性也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。

3、事务的隔离性

3.1、常见的并发异常

3.1.1 丢失更新(写问题)

  • 第一类丢失更新  某一个事务的回滚导致另外一个事务已更新的数据丢失了
  • 第二类丢失更新  某一个事务的提交导致另外一个事务已更新的数据丢失了

3.1.2 读问题

  • 脏读: 事务B读取了事务A更新的数据,然后A回滚操作,那么B读取到的数据是脏数据
  • 不可重复读: 事务B多次读取同一数据,事务A在事务B多次读取的过程中,对数据作了更新并提交,导致事务B多次读取同一数据时,结果不一致。
  • 幻读: A事务读取了B事务已经提交的新增数据。select某记录是否存在,不存在,准备插入此记录,但执行 insert 时发现此记录已存在,无法插入,此时就发生了幻读。

注意:不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。幻读不可重复读都是在同一个事务中多次读取了其他事务已经提交的事务的数据导致每次读取的数据不一致,所不同的是不可重复读读取的是同一条数据,而幻读针对的是一批数据整体的统计。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表。

3.2、事务的隔离级别

        事务的并发异常该如何解决呢?我们可以通过设置隔离级别来解决。隔离级别有四种,分别可能出现的问题见下表。

隔离级别第一类丢失更新脏读第二类丢失更新不可重复读幻读
读未提交(read-uncommitted)
读已提交(read-committed)××
可重复读(repeatable-read)××××
串行化(serializable)×××××

  • Read uncommitted:最低级别,以上问题均无法解决。
  • Read committed:如果是一个读事务(线程),则允许其他事务读写,如果是写事务将会禁止其他事务访问该行数据,该隔离级别避免了脏读,但是可能出现不可重复读。事务B事先读取了数据,事务A紧接着更新了数据,并提交了事务,而事务B再次读取该数据时,数据已经发生了改变。
  • Repeatable Read:指在一个事务内,多次读同一个数据,在这个事务还没结束时,其他事务不能访问该数据(包括了读写),这样就可以在同一个事务内两次读到的数据是一样的,因此称为是可重复读隔离级别,读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务(包括了读写),这样避免了不可重复读和脏读,但是有时可能会出现幻读。
  • Serializable :提供严格的事务隔离,它要求事务序列化执行,事务只能一个接着一个地执行,但不能并发执行,如果仅仅通过“行级锁”是无法实现序列化的,必须通过其他机制保证新插入的数据不会被执行查询操作的事务访问到。序列化是最高的事务隔离级别,同时代价也是最高的,性能很低,一般很少使用,在该级别下,事务顺序执行,不仅可以避免脏读、不可重复读,还避免了幻读

参考链接:

链接1:MySQL相关问题整理_张彦峰ZYF的博客-CSDN博客

链接2:事务的隔离级别_zhouym_的博客-CSDN博客_事务隔离级别

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值