【MySQL面试题】经典面试题之“b+树”

mysql为什么采用b+树作为索引?

为什么要使用b+树,首先我们要知道什么样的索引才是好的索引,高效的索引,我们都知道,mysql的数据是存储在磁盘的,而磁盘的io操作十分缓慢,我们通过索引去进行一次查询操作时,需要经过多次io操作,这其实是十分消耗查询时间的,也是我们不愿意看见的。

所以说,高效索引的关键就是减少io操作。

我们的b+树有着b树的特点,并且叶子节点才存储我们的数据,在非叶子节点上只会存储索引,这样一来,在相同的一个数据量下,我们的b+树能存放更多的索引,比b树更加矮胖,查询io操作更少

b+树有大量的冗余节点,在插入、删除方面效率更高。

扫表能力更强,因为我们只需要遍历叶子节点就行了,不需要遍历整个b+树就能拿到所有的数据。

在面试时建议大家这么答

Mysq|索引使用的是B+树,因为索引是用来加快查询的,而B +树通过对数据进行排序所以是可以提高查询速度的,然后通过一个节点中可以存储多个元素,从而可以使得B +树的高度不会太高,在Mysql中一 个Innodb页就是一 个B+ 树节点,一个Innodb页默认16kb, 所以一般情况下一颗三层的B+ 树可以存2000万行左右 的数据,然后通过利用B+树叶子节点存储了所有数据并且进行了排序,并且叶子节点之间有指针,可以很好的支持全表扫描,范围查找等SQL语句.

想要深入底层的了解原理推荐这篇文章: 为什么 MySQL 采用 B+ 树作为索引? | 小林coding (xiaolincoding.com)

相关推荐
杨云龙UP13 分钟前
ODA登录ODA Web管理界面时提示Password Expired的处理方法_20260423
linux·运维·服务器·数据库·oracle
解救女汉子22 分钟前
SQL触发器如何获取触发源应用名_利用APP_NAME函数追踪
jvm·数据库·python
weixin_520649872 小时前
数据库函数
数据库
Bert.Cai3 小时前
MySQL LPAD()函数详解
数据库·mysql
OnlyEasyCode4 小时前
Navicat 任务自动备份指定数据库
数据库
if else4 小时前
Redis 哨兵集群部署方案
数据库·redis
yejqvow124 小时前
Pandas 高效实现组内跨行时间戳匹配与布尔标记
jvm·数据库·python
了不起的云计算V4 小时前
从DeepSeek V4适配看国产算力的三个拐点
数据库·人工智能
qq_189807034 小时前
html标签如何提升可访问性_aria-label与title区别【指南】
jvm·数据库·python
norq juox5 小时前
MySQL 导出数据
数据库·mysql·adb