当前位置:首页 > 文章列表 > 数据库 > MySQL > 面试被吊打系列 - 事务隔离级别

面试被吊打系列 - 事务隔离级别

来源:SegmentFault 2023-01-12 18:59:13 0浏览 收藏

小伙伴们有没有觉得学习数据库很有意思?有意思就对了!今天就给大家带来《面试被吊打系列 - 事务隔离级别》,以下内容将会涉及到MySQL、面试、事务,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

小张兴冲冲去面试,结果被面试官吊打!

小张:面试官,你好。我是来参加面试的。

面试官:你好,小张。我看了你的简历,精通MySQL数据库。那你肯定知道事务吧,你能说说 事务有哪些特性 吗?

小张:一个事务有4个特性,即ACID。

  • 原子性(Atomicity): 事务开始后的所有操作,要么全部成功要么全部失败。
  • 一致性(Consistency): 事务开始前后数据库的完整性约束没有被破坏,比如:A向B转钱,不可能出现A扣了钱,B没收到钱。
  • 隔离性(Isolation):多个事务并发访问时,事务之间是隔离的。
  • 持久性(Durability):事务完成后,事务对数据库的操作被保存在了数据库,不能回滚。

面试官:嗯,答的很对。那你说说事务有哪几种隔离级别呢?

小张:事务隔离级别从高到低有四种隔离级别,分别是:串行化(SERIALIZABLE) 、可重复读(REPEATABLE READ)、读提交(READ COMMITTED)、读未提交(READ UNCOMMITTED)。

面试官:嗯嗯,那你能说说这四种隔离级别分别会造成什么问题吗?

(小张窃喜,我就知道你要这么问,还好我平时关注了 ‘ JAVA日知录 ’ 的公众号)

小张:好的,面试官。

如果数据库采用 读未提交(READ UNCOMMITTED)这种隔离级别,会造成 脏读。事务还没提交别人就能看到,这样就不能保证你读取到的数据是最终的数据,万一别人把事务回滚了,那就出现了脏数据问题。

读提交(READ COMMITTED)是指一个事务只能读取到其他事务已经提交了的数据,这样就不会出现脏读的问题,但是它会带来」不可重复读 的问题。比如 A事务 将一个人的姓名从张三改成李四,B事务在A事务提交之前读取到的是张三,但是在A事务提交之后就变成了李四。

可重复读(REPEATABLE READ):可重复读是为了解决READ COMMITTED带来的不可重复读问题,指的是事务不会读取到其他事务对已有数据的修改,即使数据已经提交了。也就是说事务开始读取到的是什么,在事务提交之前的任意时刻,这些数据都一样。虽然解决了不可重复读问题,但是他又会带来 幻读 的问题。比如A事务将张三修改成李四,B事务再插入一个名叫李四的用户,此时事务A再查找名叫李四的用户会发现多了一条,出现了2个李四,这就是幻读。

串行化(SERIALIZABLE):解决了上面出现的所有问题,但是它效率最差,它将事务的执行变成顺序执行了。

面试官:回答的不错,那你知道 MySQL的默认隔离级别是什么吗

小张:Mysql默认的隔离级别是REPEATABLE READ,Oracle则采用的是READ COMMITTED

面试官:但是我们使用MySQL的时候并没有出现幻读啊,怎么解决的?

小张擦了擦汗,开始有点紧张了:额,InnoDB主要是利用锁来解决幻读问题的。

面试官:对,是采用了锁,那么具体怎么实现的呢?

小张:我...我突然有点事,我先回去了。

面试官:要了解InnoDB怎么解决幻读得先知道InnoDB有哪几种锁。

  • Record Lock:单个行记录上的锁
  • Gap Lock:间隙锁,锁定一个范围,而非记录本身,遵循左开右闭原则
  • Next-Key Lock:结合Gap Lock和Record Lock,锁定一个范围,并且锁定记录本身。主要解决的问题是REPEATABLE READ隔离级别下的幻读。

注意,如果走唯一索引,那么Next-Key Lock会降级为Record Lock,即仅锁住索引本身,而不是范围。也就是说Next-Key Lock前置条件为事务隔离级别为RR且查询的索引走的非唯一索引、主键索引。

下面我们通过具体的例子来模拟上面出现的幻读问题:

`CREATE TABLE T (id int ,name varchar(50),f_id int,PRIMARY KEY (id), KEY(f_id)) ENGINE=InnoDB DEFAULT CHARSET=utf8`
`insert into T SELECT 1,'张三',10;`
`insert into T SELECT 2,'李四',30;`

InnoDB在数据库中会为索引维护一套B+树,用来快速定位行记录。B+索引树是有序的,所以会把这张表的索引分割成几个区间。

事务A执行如下语句,需要将张三修改成李四。

`select * from t;`
`update t set name = '李四' where f_id = 10;`

这时SQL语句走非唯一索引,因此使用

Next-Key Lock
加锁,不仅会给f_10=10的行加上行锁,而且还会给这条记录的两边添加上间隙锁,即(-∞,10]、(10,30]这2个区间都加了间隙锁。

此时如果B事务要执行如下语句,都会报错

[Err] 1205 - Lock wait timeout exceeded; try restarting transaction

`INSERT INTO T SELECT 3,'王五',10;  -- 满足行锁,执行阻塞`
`INSERT INTO T SELECT 4,'赵六',8;   -- 满足间隙锁,执行阻塞`
`INSERT INTO T SELECT 5,'孙七',18;  -- 满足间隙锁,执行阻塞`

不仅插入 f_id = 10 的记录需要等待事务A提交,

f_id 、<pre class="brush:go;">10 的记录也无法完成,而大于等于30的记录则不受影响,这足以解决幻读问题了。<blockquote>刚刚讲的是f_id 是索引列的情况,那么如果 f_id不是索引列会怎么样呢?</blockquote><p>这时候数据库会为整个表加上间隙锁。所以,如果是没有索引的话,不管 f_id 是否大于等于30,都要等待事务A提交才可以成功插入。</p><p>面试官:好了,各位看官朋友们,事务的隔离级别这个面试点你们清楚了吗?希望你们的面试不会被这个问题难倒哟~</p><p>小张:学到了学到了,我下次再来。(赶紧回去把简历上的精通数据库给删掉。)</p><p>以上,希望对你有所帮助!</p><hr><p>这里为大家准备了一份小小的礼物,关注公众号,输入如下代码,即可获得百度网盘地址,无套路领取!  </p><p>001:《程序员必读书籍》  <br>002:《从无到有搭建中小型互联网公司后台服务架构与运维架构》  <br>003:《互联网企业高并发解决方案》  <br>004:《互联网架构教学视频》  <br>006:《SpringBoot实现点餐系统》  <br>007:《SpringSecurity实战视频》  <br>008:《Hadoop实战教学视频》  <br>009:《腾讯2019Techo开发者大会PPT》</p><p>010: 微信交流群</p><p></p><center><img referrerpolicy="no-referrer" src="/uploads/20230112/167352210563bfebb94a101.jpg" alt="" title="" loading="lazy"></center><p>好了,本文到此结束,带大家了解了《面试被吊打系列 - 事务隔离级别》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!</p>
版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
使用内存NewSQL数据平台来处理实时数据流的三个好处使用内存NewSQL数据平台来处理实时数据流的三个好处
上一篇
使用内存NewSQL数据平台来处理实时数据流的三个好处
在苹果Mac上找不到文件存储位置怎么办?
下一篇
在苹果Mac上找不到文件存储位置怎么办?
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3179次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    3390次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    3419次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    4525次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    3799次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码