我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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

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

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

  • read uncommitted(读未提交)

  • read committed(读已提交)

  • repeatable read(可重复读)

  • Serializable(串行化)

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

**准备工作**

由于我本地服务器上只有一个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

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql事务隔离级别介绍和演示

什么是事务  事务是应用程序中一系列对数据库的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。  事务的结束有两种,当事务中的所有操作全部执行成功时,事务提交结束
mysql事务隔离级别介绍和演示
2017-07-12

java事务、事务的隔离级别的概念是什么

本篇内容介绍了“java事务、事务的隔离级别的概念是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是事务?  事务,即数据库事务。是
2023-06-02

MySQL的事务隔离级别

目录数据库事务的四大特性⑴ 原子性(Atomicity)⑵ 一致性(Consistency)⑶ 隔离性(Isolation)⑷ 持久性(Durability)SQL的4种隔离级别Read Uncommitted(读取未提交内容)Read Committed(读
MySQL的事务隔离级别
2021-07-07

MySQL 事务的隔离级别

1. 事务的ACID事务的ACID是指事务拥有的4个特性的首字母组合:atomicity(原子性), consistency(一致性), isolation(隔离性)和durability(持久性)。①atomicity(原子性):表示事务是一个不可分割的工作
MySQL 事务的隔离级别
2019-01-27

mysql数据库事务及隔离级别

事务的四大特性: 原子性: 事务是最小的执行单位,不允许分割。事务的原子性确保动作要么全部完成,要么完全不起作用; 一致性: 执行事务前后,数据保持一致,多个事务对同一个数据读取的结果是相同的; 隔离性: 并发访问数据库时,一个用户的事务不被其他事务所干扰,各
mysql数据库事务及隔离级别
2021-09-18

MySQL 事务 异常 事务隔离的级别 - G

MySQL 事务 异常 事务隔离的级别 事务在你操作数据库的同时,有可能其他用户还会不断地对数据进行增删改查操作。为了避免并行进行时出现混乱,就产生了“事务”。事务就是要保证一组数据库操作,要么全部成功要么全部失败,以此来保证不混乱。事务支持是在引擎层实现的,
MySQL 事务 异常 事务隔离的级别 - G
2021-07-20

MySQL锁与事务隔离级别

1、概述(1)锁的定义锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除了传统的计算资源(如CPU、RAM、IO等)的争用以外,数据也是一种供需要用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁冲突也是影响
MySQL锁与事务隔离级别
2021-12-05

MySQL的四种事务隔离级别

环境:Windows 10+cmd+MySQL5.6.36+InnoDB 一、事务的基本要素(ACID) 1.原子性(Atomicity): 事务开始后所有操作,要么全部做完,要么全部不做,不可能停滞在中间环节。事务执行过程中出错,会回滚到事务开始前的状态,所
MySQL的四种事务隔离级别
2016-09-03

MySQL事务隔离级别详解

一、什么是事务? 事务是逻辑上的一组操作,要么全执行,要么全不执行。 事务最经典栗子也经常被拿出来的栗子就是银行转账了。比如小明要给小红转账1000元,这个转账会涉及到两个关键操作:将小明的余额减1000元,将小红的余额减1000元。万一这
2023-08-30

编程热搜

目录