Mysql事务的隔离级别(脏读+幻读+可重复读)

 更新时间:2022年08月24日 16:04:02   作者:哇~是小菜呀  
这篇文章主要介绍了Mysql事务的隔离级别(脏读+幻读+可重复读),文章通告InnoDB展开详细内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下

前言:

因为InnoDB是支持事务的,所以只对InnoDB的事务进行讨论。

一、事务

(一)什么是事务

事务是由一组SQL语句组成的逻辑处理单元,是一组不可分割的操作序列。

(二)事务的特征

  • 原子性(Actomicity):事务是一个原子操作单元,其对数据的修改,要么全都执行,要么全都不执行
  • 一致性(Consistent):在事务开始和完成时,数据都必须保持一致状态。
  • 隔离性(Isolation):数据库系统提供一定的隔离机制,保证事务在不受外部并发操作影响的“独立”环境执行。
  • 持久性(Durable):事务完成之后,它对于数据的修改是永久性的,即使出现系统故障也能够保持。

(三)手动开启、提交、回滚事务

-- 开启事务
start transaction;
update user_count set balance = balance + 20 where id = 1;
update user_count set balance = balance - 20 where id =2;
-- 回滚事务
rollback;
-- 提交事务
commit;

注意:在回滚和提交之前,数据库中的数据都是操作的缓存中的数据,而不是数据库中的真实数据。

二、脏读、幻读、可重复读

(一)脏读 read uncommit

读取到了未提交的数据。

脏读对应的是read uncommitted读未提交的事务隔离级别,即从缓存中读取数据,而不是读取已经持久化的数据。

事务B在select的时候,读取到了被事务A更新在缓存的数据,但是该数据没有真正的持久化到数据库中,一旦事务A会滚,事务B就会读到错误的脏数据。

(二)不可重复读 unrepeatable

一个事务在读取某些数据已经发生了改变、或某些记录已经被删除了!这种现象叫做“不可重复读”。

不可重复读产生的场景对应的是read committed读已提交的事务隔离级别,即事务读取的数据都是已经完成持久化的数据。

(三)幻读

同一事务内,同样的筛选条件,查询出来的数据条数发生了变化,(另一个事务抢到CPU进行了删除或者插入条件),这种现象就称为“幻读” 。
幻读产生的场景对应的是repeatable read可重复读的事务隔离级别,事务读取的数据都是已经完成持久化的数据,并且为事务在修改的数据增加行锁,但是没有表锁。

(四)不可重复读和幻读的区别

不可重复读针对的是同一条数据,读的是别的事务修改之前的样子,一旦事务的隔离级别使用了unrepeatable read,加上行锁,就可以避免产生。
幻读针对的是满足筛选条件的一批数据,因为行锁不能阻止插入和删除数据,所以会导致查询到的条数是错误的,使用serializable可以避免。

三、事务的隔离级别

 脏读不可重复读幻读
read uncommitted
read committed 
repeatable read  
serializable   

设置表的隔离级别sql语言如下:

-- 查询数据库当前的隔离级别
select @@transaction_isolation
-- 读未提交
set session transaction isolation level read uncommitted;
-- 读已提交
set session transaction isolation level read committed;
-- 不可重复读
set session transaction isolation level repeatable read;
-- 序列化(串行执行)
set session transaction isolation level serializable;

(一)读未提交read uncommitted

读缓存里面的数据,风险最高但是允许的并发最多

(二)读已提交read committed

读持久化的数据,不读缓存的数据,不加锁

(三)不可重复读 read repeatable

读可持久化的数据的数据,并且添加行级锁(一个事务在修改某行数据的时候,别的事务阻塞等待提交才能读到)

(四)序列化 serializable

最安全但是并发效率最低,读持久化数据,并且加表锁,如果事务并发的多,需要一直阻塞,不建议使用。

事务的隔离级别从低到高依次是 read uncommitted , read committed, repeatable read , serializable 。隔离级别越低,越能支持高并发的数据操作,与此同时,也会带来越高的并发风险,Mysql数据库默认的隔离级别是repeatable read 。

到此这篇关于Mysql事务的隔离级别(脏读+幻读+可重复读)的文章就介绍到这了,更多相关Mysql事务隔离内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL每天自动增加分区的实现

    MySQL每天自动增加分区的实现

    本文主要介绍了MySQL每天自动增加分区的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • 解读SQL中GROUP BY和HAVING子句中使用NULL条件问题

    解读SQL中GROUP BY和HAVING子句中使用NULL条件问题

    在使用SQL进行数据查询时,可能会遇到查询结果为空的情况,这通常与GROUP BY和HAVING子句的使用有关,尤其是在处理包含NULL值的字段时,当使用GROUP BY进行数据分组,并在HAVING子句中直接判断字段是否为NULL时
    2024-10-10
  • MySQL三种打开方式详细图文教程

    MySQL三种打开方式详细图文教程

    MySQL有多种打开方式,具体取决于你的操作系统和安装方式,下面这篇文章主要给大家介绍了关于MySQL三种打开方式的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-07-07
  • MySQL中EXPLAIN的/基本使用及字段详解

    MySQL中EXPLAIN的/基本使用及字段详解

    EXPLAIN命令是MySQL中用于解析SQL查询语句的工具,帮助开发者理解MySQL如何执行SQL语句,通过EXPLAIN可以查看SQL执行的详细信息,如表的读取顺序、使用的索引、数据读取操作的类型等,这篇文章主要介绍了MySQL中EXPLAIN的/基本使用及字段详解,需要的朋友可以参考下
    2024-09-09
  • MySQL之PXC集群搭建的方法步骤

    MySQL之PXC集群搭建的方法步骤

    PXC 是一套 MySQL 高可用集群解决方案,本文主要介绍了MySQL之PXC集群搭建的方法步骤,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • mysql日志文件之undo log和redo log

    mysql日志文件之undo log和redo log

    MySQL日志记录了MySQL数据库日常操作和错误信息,MySQL有不同类型的日志文件,下面这篇文章主要给大家介绍了关于mysql日志文件之undo log和redo log的相关资料,需要的朋友可以参考下
    2022-04-04
  • docker下mysql 8.0.20 安装配置方法图文教程

    docker下mysql 8.0.20 安装配置方法图文教程

    这篇文章主要介绍了docker下mysql 8.0.20 安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • MySQL半同步复制原理配置与介绍详解

    MySQL半同步复制原理配置与介绍详解

    这篇文章主要介绍了MySQL半同步复制原理配置与介绍详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01
  • MySQL主从复制原理详情

    MySQL主从复制原理详情

    这篇文章主要介绍了MySQL主从复制原理详情,MySQL 主从复制是指数据可以从一个MySQL数据库服务器主节点复制到一个或多个从节点,文章围绕主题展开详细的内容介绍。感兴趣的小伙伴可以参考一下
    2022-06-06
  • MariaDB(Mysql分支)my.cnf配置文件中文注释版

    MariaDB(Mysql分支)my.cnf配置文件中文注释版

    这篇文章主要介绍了MariaDB my.cnf配置文件中文注释版,MariaDB是Mysql的一个分支,完全兼容Mysql,需要的朋友可以参考下
    2014-06-06

最新评论