美文网首页数据库
mysql索引数据结构介绍

mysql索引数据结构介绍

作者: 为爱放弃一切 | 来源:发表于2019-02-19 17:06 被阅读123次

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

image

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

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

面试现场

image image

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

image image image image image

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

image

小史:底层MySQL是存储,Redis是缓存,DAO层操作MySQL,Cache层操作Redis,Service层处理业务逻辑,Rest API层为前端提供Rest接口。前端这边用React进行模块化,Webpack打包部署。网关Nginx进行负载均衡。MySQL、Redis、Nginx和SpringBoot应用都放在Docker里部署。

image image image image image image image image image image image image image image

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

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

image

前段时间的饭局

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

image image

【饭后】

image image

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

image image image

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

【红黑树】

image

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

image

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

image

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

image image image image image image image image image image image image image image image

【B树】

image image image image image image image image image image image image image image image image image

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

image

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

image image image image image image

【B+树】

image image image image image image image

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

image

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

image image

image

回到现场

image image

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

image

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

image

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

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

image

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

image image

亲爱的读者们,面试现场的第一季到这里就全部结束了,感谢大家的支持,我们一起期待小史后面的故事。

相关文章

  • Mysql索引学习

    Mysql索引 介绍: 索引是帮助mysql高效获取数据数据的排好序的数据结构。 我们从以下数据结构逐步探讨: 演...

  • MySQL 索引和索引优化分析

    索引简介 介绍 索引(index)是帮助MySQL高效获取数据的数据结构。 可以理解为:索引是数据结构;或者排好序...

  • 05 MySQL-初识MySQL-索引-下

    04 MySQL-初识MySQL-索引-上 篇中介绍了InnoDB索引的数据结构模型以及索引维护。本篇继续针对My...

  • 索引

    索引(Index)是帮助MySQL高效获取数据的数据结构,即索引是数据结构。MySQL索引的建立对于MySQL的高...

  • MySQL 性能调优

    MySQL性能调优 索引 索引是什么 官方介绍索引是帮助MySQL高效获取数据的数据结构。笔者理解索引相当于一本书...

  • MySQL 索引分类

    MySQL索引的分类(根据数据结构) 索引的本质 MySQL官方对索引的定义为:索引(Index)是帮助MySQL...

  • MySQL索引背后的数据结构及算法原理

    参考来源 mysql索引分析 MySQL索引背后的数据结构及算法原理 MySQL中EXPLAIN命令详解 索引连接...

  • Mysql 相关

    MySQL索引 MySQL索引背后的数据结构及算法原理 覆盖索引和回表操作 MySQL性能优化 MySql表分区详...

  • MySQL索引

    索引介绍 索引是什么 官方介绍索引是帮助MySQL高效获取数据的数据结构。更通俗的说,数据库索引好比是一本书前面的...

  • Mysql索引相关

    此文章主要回答以下问题:1 、索引数据结构演变2 、mysql索引数据结构 mysql索引的演变 线性结构:首先不...

网友评论

    本文标题:mysql索引数据结构介绍

    本文链接:https://www.haomeiwen.com/subject/lhufyqtx.html