前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【面试现场】为什么MySQL数据库要用B+树存储索引?

【面试现场】为什么MySQL数据库要用B+树存储索引?

作者头像
用户1260737
发布2019-03-08 16:00:19
发布2019-03-08 16:00:19
9650
举报
文章被收录于专栏:趣谈编程趣谈编程

来源:互联网侦查

作者:channingbreeze

小史是一个应届生,虽然学的是电子专业,但是自己业余时间看了很多互联网与编程方面的书,一心想进BAT互联网公司。

话说两个多月前,小史通过了A厂的一面,两个多月后的今天,小史终于等到了A厂的二面。

简单的自我介绍后,面试官看了看小史的简历,开始发问了。

【面试现场】

小史:没问题,这个项目前端用的react+webpack,后端用的nginx+SpringBoot+Redis+MySql,前后端分离的,最后用docker进行容器化部署。主要模块有师生系统、课程系统、成绩系统、选课系统等。

这个项目的架构和说辞,小史早已背得溜溜的。

小史:底层mysql是存储,redis是缓存,dao层操作mysql,cache层操作redis,service层处理业务逻辑,rest api层为前端提供rest接口。前端这边用react进行模块化,webpack打包部署。网关nginx进行负载均衡。mysql、redis、nginx和springboot应用都放在docker里部署。

涛声依旧注:给字段建立索引其实就是把这个字段(比如id)的所有值组织成一个数据结构(比如B+树),那这个值就充当了一个索引(Key),用它可以找到它那一行的数据,也就是值(Value)。

题目:为什么MySQL数据库要用B+树存储索引?

小史听到这个题目,陷入了回忆。

【前段时间的饭局】

话说吕老师给小史讲完人工智能的一些知识后,他们一起回家吃小史姐姐做的饭去了。

【饭后】

吕老师:面试的时候一定是往深了问,不精通的话容易吃亏。不过面试时一般都是根据项目来问,项目中用到的技术,一定要多看看原理,特别是能和数据结构和算法挂钩的那部分。

小史:树的话,无非就是前中后序遍历、二叉树、二叉搜索树、平衡二叉树,更高级一点的有红黑树、B树、B+树,还有之前你教我的字典树。

【红黑树】

一听到红黑树,小史头都大了,开始抱怨了起来。

小史:红黑树看过很多遍了,但是每次都记不住,它的规则实在是太多了,光定义就有四五条规则,还有插入删除的时候,需要调整树,复杂得很。

吕老师:小史,问你红黑树,并不是让你背诵它的定义,或者让你手写一个红黑树,而是想问问你它为什么这样设计,它的使用场景有哪些。

【B树】

吕老师:小史,你要知道,文件系统和数据库的索引都是存在硬盘上的,并且如果数据量大的话,不一定能一次性加载到内存中。

两个月前,小史面试没考虑内存情况差点挂了,传送门

涛声依旧注:如果是红黑树的话,每个节点只有一个数,那么对于树的高度就会比B树的高(B树一般每个节点会存储很多数(Key)),这样的话,每次读入一个节点都会进行一次IO,所以红黑树由于树的高度太高而进行了太多的磁盘IO不可取(磁盘IO的次数和树的高度有关)。

【B+树】

吕老师:这也是和业务场景相关的,你想想,数据库中select数据,不一定只选一条,很多时候会选多条,比如按照id排序后选10条。

小史:我明白了,如果是多条的话,B树需要做局部的中序遍历,可能要跨层访问。而B+树由于所有数据都在叶子结点,不用跨层,同时由于有链表结构,只需要找到首尾,通过链表就能把所有数据取出来了。

涛声依旧注:在进行范围查询的时候,比如 select * from where id <= 7 and id >= 19,如果是B树,此时遍历整个B树很多次,一一找到那些 id 符合条件的所有节点,然后再找到你所需要的信息。而B+树只需要从根节点找到起始位置(id=7),然后顺着链表一直遍历,直到终止位置(id=19);

涛声依旧注:以上查找的数字都是都是索引(Key),而你所要查找的值也就是你要select的东西,根据不同的存储引擎存储的位置不一样,MyISAM是在叶子节点存储一个指针,指向你所要查找的数据,而InnoDB是直接存储在叶子节点的(也就是说索引和你要查的数据在一块)。

【回到现场】

小史:这和业务场景有关。如果只选一个数据,那确实是hash更快。但是数据库中经常会选择多条,这时候由于B+树索引有序,并且又有链表相连,它的查询效率比hash就快很多了。

小史:而且数据库中的索引一般是在磁盘上,数据量大的情况可能无法一次装入内存,B+树的设计可以允许数据分批加载,同时树的高度较低,提高查找效率。

HR和小史简单地聊了聊基本情况,这次面试就结束了。

小史走后,面试官在系统中写下了面试评语:

几天后,小史收到了A厂的offer。

-END-

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-01-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 趣谈编程 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档