前言

面试中我们经常碰到面试官问到数据库索引,问到索引就会问你索引的数据结构。类似这种数据结构对于普通程序员来说记住概念几天就忘了,而且概念不是每个人都能很好都理解,所以针对这一原因,我简单通俗都像大家讲解为什么mysql使用都是B+树,而不用其他的树形结构。

正文

Q1:B+树的查询时间大概多少?

A:跟树的高度有关,是O(log n)。

Q2:hash查找时间大概多少?

A:o(1)。

Q3:hash比B+查找时间更短,为什么索引不用hash?

A:这和业务场景有关,如果只查找一个值的话,hash是一个很好的选择,单数据库经常会选择多条,这时候由于B+树索引有序,并且又有链表相连,它的查询效率比hash就快很多了。而且数据库中的索引一般是在磁盘上,数据量大的情况可能无法一次装入内存,B+树的设计可以允许数据分批加载,同时树的高度较低,提高查找效率。

下面我对第三个问题进行一个解析,让大家更好的记住。

二叉排序树

同一高度下左边跟节点小,右边跟节点大,并且左右子树都是二叉排序的。但是在极端情况下插入的是有序的序列就会变成链表。

所以这时候我们就要对二叉树进行平衡,让插入的时候节点能均匀分布。

红黑树

性质1. 节点是红色或黑色。

性质2. 根节点是黑色。

性质3 每个叶节点(NIL节点,空节点)是黑色的。

性质4 每个红色节点的两个子节点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色节点)

性质5. 从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点。

所以引入红黑树,红黑树是平衡树的一种,他的复杂规则都是为了保证树的平衡,所以大家在记概念的时候理解不上去。

我们知道,树形结构的数据查找速度跟树的高度有关,所以尽可能让树平衡就是为了降低树的高度,java里有一种s数据结构底层就用的红黑树,就是TreeSet。

B树

也叫B-树,大家千万不要说B减树。

B树是一种多路搜索树,每个节点都可以有多于两个子节点,M路的B树就是有最多有M个子节点。

这就是一个3路B树

多路的结构就是为了尽可能降低树的高度,使查询速度更快,有一种情况就是无限多路,那就变成一个数组了,所以我们树ArrayList适合用来查询,数组结构的数据都有这个特点。

所以我们常常用B树做文件系统的索引,因为我们文件和数据库的索引都是存在硬盘上的,并且如果数据量大的话,不一定能一次性加载到内存中。所以一棵树无法全部加载到内存里我们怎么查找,这时候就用到我们刚才说到的B树了,我们可以每次加载树的每一个节点,然后一步一步往下查找,而且多路B树每个节点会多于两个子节点,速度会更快,所以我们不用红黑树,因为红黑树子节点只有两个。

B+树

B+树是在B树基础上改造的,他的数据都在叶子节点,同时叶子节点还加了指针。

这是一个四路B+树,叶子节点都数据形成了链表

这也是和业务场景相关的,你想想,数据库中select数据,不一定只选一条,很多时候会选多条,比如按照id排序后选10条。如果是多条的话,B树需要做局部的中序遍历,可能要跨层访问。而B+树由于所有数据都在叶子结点,不用跨层,同时由于有链表结构,只需要找到首尾,通过链表就能把所有数据取出来了。

比如我们查找7到19,B+ 都威力看到了吧。所以小伙伴们回到前文都三个问题中,就知道了为什么MySql索引使用B+树了吧。

mysql索引 红黑树_为什么MySql索引使用B+树?相关推荐

  1. mysql 红黑树_微信大牛教你深入了解数据库索引

    | 作者刘国斌,腾讯微信事业群研发工程师,目前从事企业微信的后台研发工作,已经参与企业微信消息系统.群聊.客户联系等企业微信多个核心功能的迭代. 数据库查询是数据库的最主要功能之一. 我们都希望查询数 ...

  2. B-Tree/B+-Tree/二叉树/红黑树/Hash表/MySQL底层到底用哪个数据表建立索引做快速查找?

    B-Tree/B+-Tree/二叉树/红黑树/Hash表/MySQL底层到底用哪个数据表建立索引做快速查找? ~~B-Tree~~ ==B+Tree== ~~二叉树(Binary Search Tre ...

  3. java 二叉树 红黑树_常见数据结构(二)-树(二叉树,红黑树,B树)

    常见数据结构(二)-树(二叉树,红黑树,B树) 标签: algorithms [TOC] 本文介绍数据结构中几种常见的树:二分查找树,2-3树,红黑树,B树 写在前面 本文所有图片均截图自course ...

  4. 自顶向下红黑树java,【CPP】各种各样的树(9)——自顶向下的红黑树

    当前浏览器不支持播放音乐或语音,请在微信或其他浏览器中播放 本以为春节后马上就能写完这些树了,结果没想到一拖再拖居然拖到了开学前,很真实.红黑树还是蛮难的,写着写着才意识到应该先搞完B树然后再写2-3 ...

  5. mysql explain详解_数据库mysql(1)——B+TREE索引原理

    一.B+Tree索引详解 1.什么是索引? 索引:加速查询的数据结构. 2.索引常见数据结构: #1.顺序查找: 最基本的查询算法-复杂度O(n),大数据量此算法效率糟糕. #2.二叉树查找(bina ...

  6. 建立了索引怎么使用_对MySQL索引的认识

    1.你一般怎么建索引的? 去my.cnf里配置三个配置 打开慢查询日志slow_query_log=1慢查询日志存储路径slow_query_log_file=/var/log/mysql/log-s ...

  7. mysql建索引 字段截取_提高MySQL索引策略一:隔离查询列

    在mysql中执行查询时,如果没有将查询条件(条件列)隔离出来,那么查询引擎则无法利用建立在该列上的索引进行数据获取.这里的"隔离"意味着查询条件字段不能作为表达式的一部分出现,所 ...

  8. mysql使索引失效语句_会导致索引失效语句

    1.使用like关键字模糊查询时,% 放在前面索引不起作用,只有"%"不在第一个位置,索引才会生效(like '%文'–索引不起作用) 2.使用联合索引时,只有查询条件中使用了这些 ...

  9. mysql not exists无效_分析MySQL中哪些情况下数据库索引会失效

    要想分析MySQL查询语句中的相关信息,如是全表查询还是部分查询,就要用到explain. 一.explain 用法:explain +查询语句. id:查询语句的序列号,上面图片中只有一个selec ...

最新文章

  1. 通过代码动态创建IIS站点
  2. 关于分组序号在MySQL中的实现
  3. AngularJS-demo - 常用命令、内置服务、自定义服务、继承
  4. 并发下,使用redis防止数据重复插入(数据库未对表字段设置唯一情况下)
  5. DB2数据库对现有表格字段修改
  6. 0712 - 坚守,加强老本
  7. text——Android下的默认字体详解
  8. 磁珠 符号_FB是磁珠的符号 | 学步园
  9. Mysql开启局域网连接
  10. 11月20日云栖精选夜读:围观阿里总部:边喝茶边搞技术是一种怎样的体验?
  11. sql注入--宽字节注入
  12. c程序设计总结(红皮书+真题)
  13. 系数为多项式的幂级数求和
  14. Python 123精品卷一
  15. sublime text (ST)一篇通(安装、配置、扩展、使用)
  16. android机开应用速度慢,Android机跑好慢 学会这秘密五招手机瞬间加速!
  17. unity 在game视图模型穿插问题
  18. 基于JavaSwing+Mysql的仓库管理系统设计和实现
  19. 如何基于java代理对大数据缓存组件返回的数据进行脱敏和阻断
  20. JavaScript高级(BOM+DOM)学习

热门文章

  1. 深度行情模块添加【火币交易助手开发日记】
  2. 浅谈 TypeScript【上】-- Flow 静态类型检查工具
  3. C#LeetCode刷题之#724-寻找数组的中心索引( Find Pivot Index)
  4. macos必做的设置_如何在MacOS上设置PHP,CaddyServer和Kirby —以及为什么要这样做
  5. git规则写法_3条简单的规则将帮助您成为Git大师
  6. 随机过程第1讲——泊松过程的模拟与检验
  7. 关于Oxygen版 Eclipse JSP或html 中option标签使用c:if报错的问题
  8. 使用Python进行汽车黑客攻击:泄露GPS和OBDIICAN总线数据
  9. Python getattr() 函数
  10. 优化 Hive ETL 任务(参数篇)