数据库索引原理

什么是索引

在数据库中,索引是一种已经排好序的数据结构

数据结构
  • 二叉树
  • 红黑树
  • 哈希表
  • B树
对比
  • 搜索二叉树:将索引排序成一个搜索二叉树,每个节点的值指向对应表记录的磁盘地址。

    • 优缺点
      • 速度快,时间复杂度可以达到Ologn
      • 当索引是自增的主键时,搜索二叉树将退化为单链表,因此存在局限性
  • 红黑树:在插入数据时,如果单边过长,会自动的平衡(自旋),相当于优化的搜索二叉树

    • 优缺点
      • 在搜索二叉树的基础上有更强的适应性
      • 但是当数据量很大时(几千万),索引树的高度会非常高,这时如果我们查找的数据在靠底层的节点时,效率会非常的低下。因此,我们需要减少树的高度
  • B tree:树的每个节点不再是一个元素,而是划分范围,每个节点的子节点处于父节点的范围中类似这样的图(本图为B+树,B树的子节点之间没有指针连接):网图侵删

    • 优缺点
      • B树的引入大大降低了树的高度,可以提升我们的查找速度
      • B树的每个节点中包含了本身的data,而计算机每次的磁盘IO有限度,为了使计算机每次可以尽可能多的将索引读入内存,我们需要减少节点的空间,因此引出了数据库使用的B树变种,B+树(注:mysql对每个节点的大小限制在16K)
  • B+ tree:相对于B树,B+树的父节点只保存索引,只有叶子节点才保存索引和data,这样可以使得父节点包含更多的索引,同时B+树的叶子节点之间存在双向指针,便于范围搜索。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值