MYSQL索引的底层数据结构

MYSQL索引

啥是索引,为什么要用索引,怎么用,为什么要用

索引:就好像查字典一样,通过偏旁部首,声母韵母这种方式去查某个字,会让你的效率更高更快。

在mysql中,索引是一种数据结构,他的功能和查字典没啥两样,主要就是让数据检索的效率更快。

Mysql索引的数据结构的选择:

  1. 不是说hash查找的时间复杂度是o(1),为什么不使用哈希查找?

因为一般来说我们存储的数据都是范围的存储,数据的左右多少都是有点关系的,但是哈希查找不是这样的,他说通过计算哈希值,把每个数据放到某个位置去,他不支持范围查找数据的关联系比较弱。

  1. 为什么不使用二叉搜索数

因为最坏的情况下,二叉搜索树可能会退化成一个单分支的数,这个时候的二叉搜索树其实和单链表没啥区别了时间复杂度都是o(n),并且数据库的数据是保存在磁盘上的,也就是相当于每次访问一个数据都要发生一次磁盘oi(开关)。

  1. 为什么不使用N叉数(B树)

时间复杂度o(logn)

树的高度被有效控制,查询数据的次数变少了,数据库的效率也提升了,为什么不使用呢,是因为有更好的B+树

4为什么索引选择了使用B+树(面试题)

B+树,时间复杂度是o(logn);

仔细观察这个B+树和B树

这两棵树有什么区别吗?

  1. B+树的所有叶子节点之间相当于一个双向循环列表,通过其中的任意一个元素都能找到他的兄弟节点。
  2. 非叶子节点保存的只是对子节点的引用,所有的真实数据都保存在叶子节点中。
  3. B+树和B树,在树高都一样的情况下,查找任一元素都时间复杂度都一样,性能更加均衡。
相关推荐
Jim60017 小时前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL1 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二4 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐5 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
Darling噜啦啦5 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle