mysql innodb的事业隔离级别_sqlserver事务隔离级别

mysql innodb的事业隔离级别_sqlserver事务隔离级别在Mysql中,事务主要有四种隔离级别,今天我们主要是通过示例来比较下,四种隔离级别实际在应用中,会出现什么样的对应现象。Readuncommitted(未提交读)Readcommitted(已提交读)Repeatableread(可重复读)Serializable(可串行化)在理解四种隔离级别之前,我们需要先了解另外三个名词:脏读不可重复读幻读脏读A事务,会读取到B事务还未提交的数…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

在Mysql中,事务主要有四种隔离级别,今天我们主要是通过示例来比较下,四种隔离级别实际在应用中,会出现什么样的对应现象。

Read uncommitted (未提交读)

Read committed (已提交读)

Repeatable read (可重复读)

Serializable (可串行化)

在理解四种隔离级别之前,我们需要先了解另外三个名词:

脏读

不可重复读

幻读

脏读

A事务,会读取到B事务还未提交的数据。因为B事务可能会因为各种原因数据回滚,所以如果A事务读取了B未提交的数据,然后基于此进行一些业务操作,但是B事务发生错误回滚了,那A事务的业务操作就错了。

不可重复读

在同一个事务生命周期内,也就是这个事务还未提交之前。如果另外一个事务,对数据进行了编辑(update)或者删除(delete)操作。那么A事务就会读取到。简单理解,就是在一个事务生命周期内,多次查询数据,每次都可能查出来的不一样。

幻读

幻读的结果其实和不可重复读是一样的表现,差异就在于,不可重复读,主要是针对其他事务进行了编辑(update)和删除(delete)操作。而幻读主要是针对插入(insert)操作。也就是在一个事务生命周期内,会查询到另外一个事务新插入的数据。

下面我们就直接来通过实验来看,Mysql Innodb中,不同的事务隔离级别,会出现怎么样的结果。

首先我们开启两个终端,查询当前MySQL的默认隔离级别:

SELECT @@global.tx_isolation; //查询全局事务

SELECT @@session.tx_isolation; //查询当前会话事务

2.png

可以看到,默认的隔离级别是:REPEATABLE-READ

1.实验Read uncommitted

我们将会话事务设置为:Read uncommitted

SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

//测试可以不用设置全局事务

SET GLOBAL TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;(这个可以不用设,只设置上面一行就可以了进行测试了)

更改完之后,重新查询事务:

3.png

可以看到,全局事务已经更改为Read uncommitted

然后,我们首先创建一个测试的数据库test_tx,并插入了2条测试数据,如下图:

4.png

然后我们分别开启事务,然后我们在B终端中,插入一条数据,但是不提交,然后在A终端进行数据查询。

6.png

可以看到,我们在B终端insert一条数据,但是未进行提交操作(commit),但是在A事务中,却查询到了。我们称这种现象叫做脏读,在实际开发过程中,我们一般较少使用Read uncommitted隔离级别,这种隔离级别对任何的数据操作都不会进行加锁。

2.实验Read committed

首先我们将会话的事务隔离级别设置为read committed

SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;

然后我们用上面相同的方式,进行测试。首先同时将2个终端的事务开启:begin;,然后在B终端中插入一条新的数据insert into test_tx values(4,”Lee”);,但是不提交事务(commit),然后在A终端中,查询数据,如图,我们在A终端中,没有查询到刚才插入的这条数据。

7.png

所以,实验表明,在Read committed隔离级别,不会出现脏读的问题。

然后我们继续做实验,看看在Read committed隔离级别中,会不会出现不可重复读、幻读的现象。

我们同时打开两个终端的事务,然后在A终端中,查询当前的数据,然后我们在B终端中,将ID为3的数据,name修改为Jeff。然后将B终端的事务提交(commit),但是A终端不提交事务,在一个事务的生命周期内,然后查询数据,我们查询到了刚才B终端修改过的数据。也就是说,我们在A终端的一个事务周期内(事务未commit),两次查询,得到的结果是不一样的。

8.png

实验表明,在Read committed隔离级别中,存在不可重复读的现象。

我们继续做实验,因为刚才B终端已经将事务提交,所以我们重新打开B终端的事务,然后我们在B终端中,插入(insert)一条ID为5的新数据,并提交事务。然后我们回到A终端,查询数据,我们同样可以查询到刚才B终端新插入的数据。也就是说我们在A终端中,三次查询,得到的结果都是不一样的。

9.png

实验表明,在Read committed隔离级别中,存在幻读的现象。

总结,在Read committed隔离级别中,可以有效解决脏读问题,但是有不可重复读、幻读问题,而不可重复读和幻读的差异主要是,不可重复读主要是针对修改和删除操作、幻读针对插入数据操作。

3.实验Repeatable read

首先我们将隔离级别更改为Repeatable read

SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;

然后我们首先实验,在Repeatable read级别中是否存在脏读问题,我们首先同时开启A,B两个终端的事务(begin;),然后在B终端中,插入一条ID为6的数据,但是不提交事务。然后在A终端中进行数据查询,结果是我们未查询到刚才插入的数据,所以在Repeatable read级别中,没有脏读现象。

10.png

接着,我们顺着刚才的新插入的数据,然后将B终端的事务进行提交,然后再回到A终端查询数据,依然没有查询到B终端刚才插入的ID为6的数据,以此也就表明,目前Mysql 5.6以上的版本中,Repeatable read级别已经不存在幻读的问题,而之前的版本我并未做测试,后面有时间会在去查一下,mysql是在哪个版本开始解决了幻读问题。

11.png

由于刚才B终端已经提交了事务,所以为了实验是否存在不可重复读的现象,我们重新开启B终端的事务,然后我们将ID为5的name修改为Joy:update test_tx set name = “Joy” where id = 5;,同时B终端的事务commit;,然后我们回到A终端进行查询,三次的查询结果都是一致的。所以实验表明,在Repeatable read级别中,不存在不可重复读现象。

12.png

总结,在Repeatable read级别中,脏读、不可重复读、幻读现象都没有。在mysql中,该级别也是默认的事务隔离级别,我们日常在开发中,也是主要使用该隔离级别。

4.Serializable

Serializable完全串行化的读,每次读都需要获得表级共享锁,读写相互会相互互斥,这样可以更好的解决数据一致性的问题,但是同样会大大的降低数据库的实际吞吐性能。所以该隔离级别因为损耗太大,一般很少在开发中使用。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/183920.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • B站视频API接口_视频搜索接口

    B站视频API接口_视频搜索接口Vue2.5打造简洁视频webapp项目api接口此文档为非官方接口文档,无法保证接口有效性。以下接口为本项目目前使用的接口(也可以直接看src/api/文件目录下的接口)仿B站视频网站项目源码:进入项目源码仓库了解项目更多内容请看:Vue2.5打造简洁视频webapp(近期停更。。。)首页模块推荐视频https://www.bilibili.com/index/ding.json搜索模块默认搜索词http://api.bilibili.cn/x/web-interface/sear

    2022年10月4日
    7
  • Python该怎么入门?Python入门教程(非常详细)「建议收藏」

    Python该怎么入门?Python入门教程(非常详细)「建议收藏」Python要学多久可以学会,达到精通呢?任何知识都是基础入门比较快,达到通晓的程序是需求时日的,这是一个逐渐激烈的进程。通晓任何一门编程语言,都需求通过大量的实践来积累经验,解决遇到的各种疑难问题,看别人的源码,分享自己的分码的这个进程,才能够通晓Python的方方面面。一个对Python程序能算的上通晓的程序员,对相同一个问题,他知道很多种解决问题的方法,并能从中挑选最有功率的方法!…

    2022年8月29日
    5
  • PotPlayer下载与使用

    PotPlayer下载与使用下载安装说起来,Potplayer的下载其实并不轻松,它在国内是没有自己的官网;虽然你简单百度下,总能找到下载网站,但是并不能保证其安全和纯净,个人建议从这个官网下载:下载入口:Potplayer官网/公众号分享Potplayer的官网提供有64位和32位两种版本,我们只需要选择好适合自己系统类型的版本,点击下载;一般系统都是64位,如果还不知道的自己电脑系统类型,那么右键桌面“我的电脑”图标,选择“属性”,进入之后,即可查看;下载完成后,得到一个exe文件,双击打开;依次点击“下一步

    2022年7月12日
    36
  • cmap用法,很详细(转)

    http://hi.baidu.com/wei83523408/blog/item/878ebd3b8898d5e115cecb2b.html一、Map的基本知识  映射(Map),又称为字典(Dictionary),是由关键字(Key)及其对应的元素值(Value)所组成的元素单元(Element)的表单式集合。通常,对于Map而言,使用给定的Key,可以迅速地从

    2022年4月3日
    213
  • 推荐姊妹篇:搜索中的深度匹配模型

    推荐姊妹篇:搜索中的深度匹配模型文章作者 辛俊波腾讯高级研究员编辑整理 HohXil 内容来源 作者授权出品平台 DataFunTalk 导读 在上一篇文章 推荐系统中的深度

    2025年10月10日
    4
  • renren-fast 与 renren-fast-vue 与 renren-generator 基本操作[通俗易懂]

    renren-fast 与 renren-fast-vue 与 renren-generator 基本操作[通俗易懂]一、前言公司主打产品的,近来发现了一款快速完成前后端CRUD的框架renren-fast,打算用它来“刷”小型的外包,积攒资金。个人觉得,renren-fast主要面向后台开发者,使用方式和Guns类似:使用Guns自动生成SpringBoot+LayUI的后台管理系统①由于完整开发文档需要费用,②前端使用vue,有的后台开发者不清楚。笔者参考了…

    2022年7月28日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号