文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL事务的概念以及事务隔离级别介绍

2024-04-02 19:55

关注

本篇内容主要讲解“MySQL事务的概念以及事务隔离级别介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL事务的概念以及事务隔离级别介绍”吧!

先简单介绍一下MySQL中事务的概念,它是指: 用于实现某种行为的SQL语句的组合,可以是单条SQL语句,也可以是多条。 就像线程一样,MySQL服务器允许多个事务并发执行去更新某些数据,为了保障安全,MySQL提供了四种隔离级别,用来限制不同事务之间的干扰。

四种隔离级别如下(按照级别由低到高):

接下来按照这个顺序分别进行演示。

**准备工作**

由于我本地服务器上只有一个root用户,为了后续的演示操作,所以需要再新建一个用户testB,并授予相应权限。方便起见,下文中root、testB开启的事务称为A、B。

一、read uncommitted(读未提交)

分别登录到用户root和testB,以表t_ss作为实验表,通过查询可以看到表t_ss是空的。

MySQL事务的概念以及事务隔离级别介绍

分别将root和testB的隔离级别设置为 read uncommitted( 读 未提交)。

接着分别在root、testB中开启事务A、B,然后在B中向表t_ss插入一条数据。 这时候B中的事务还没有提交(commit),我们再在A中查表,可以看见, 即使B的事务还未提交,A中也可以查询到事务B插入的数据。

MySQL事务的概念以及事务隔离级别介绍

到这大家应该都能理解 read uncommitted( 读 未提交) 的含义了,通俗来说就是: 即使事务B没有commit,其它事务也能读取到事务B更新的数据,即能够读取事务没有提交的数据。 这是事务隔离级别中等级最低的一个。

二、read committed(读已提交)

将root和testB的事务隔离级别设置为 read committed(读已提交)。

MySQL事务的概念以及事务隔离级别介绍

同样开启两个事务,并在B中再插入一条数据,此时B事务未提交,当在A中查询时,发现并未查询到B新插入的数据。

MySQL事务的概念以及事务隔离级别介绍

当commit事务B后,A成功读取到B插入的数据。

MySQL事务的概念以及事务隔离级别介绍

总结一下,在read committed(读已提交)级别时, 其它事务只能读取事务B提交后的数据,未提交则读取不到。 这是大部分数据库的默认隔离级别。

三、repeatable read(可重复读)

将事务隔离级别设置为 repeatable read(可重复读) ,并分别开启事务。

MySQL事务的概念以及事务隔离级别介绍

A先查表,有两条数据,然后B插入一条数据并commit,A再查表,结果还是两条数据,但是B中查表所得结果是三条数据。(箭头指示命令执行顺序)

MySQL事务的概念以及事务隔离级别介绍

也就是说,当数据库处于repeatable read(可重复读)时, 同一个事务前后两次所读取的数据必须是一致的,无论事务B有没有插入数据。 它是MySQL的默认隔离级别。

四、Serializable(串行化)

将root的隔离级别设置为 Serializable(串行化) ,开启事务。当在事务A中查询表t_ss且未commit时,B事务一直在等待,到达指定时间后会报错,显示超时。

MySQL事务的概念以及事务隔离级别介绍

在事务A提交后,事务B才能够成功插入数据。

MySQL事务的概念以及事务隔离级别介绍

Serializable(串行化)是等级最高,要求最严的事务隔离级别,在这种情况下, 其它事务必须等待当前事务commit后才能执行。

到此,相信大家对“MySQL事务的概念以及事务隔离级别介绍”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯