码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 面试:“索引背后的数据结构是什么样的?”,五分钟带你了解“B树,B+树”


    索引背后的数据结构是什么样的?

    是哈希表吗?

            不是,虽然哈希表的增删查改速度都很快,但对于 大于、小于、between and...这类比较大小的范围查询可能是不行的;

    会是二叉搜索树、AVL树、红黑树吗?

            二叉搜索树的最坏情况,单枝树最坏情况,时间复杂度为 O(N),即使是AVL树、红黑树、这种尽可能平衡的二叉搜索树,时间复杂度为O(logN),当数据库的数据特别多时,这些树的高度也就会非常高(logN),这和比较次数是相关的,如果是在内存中比较,多比较几次倒也无所谓,因为内存的访问速度很快,但如果实在硬盘上进行的,那就要思量一下了~

    所以,程序猿为数据库的索引专门定制了一个数据结构——B+树


    什么是B树?

            要想了解B+树,首先来了解一下什么是B树:

            如下图

             B树是一个N叉搜索树,每个结点可能包含 N - 1 个值,这 N - 1个值就把区间划分成N份,并且每个结点值不能重复出现,这样划分有什么意义呢?就是表示相同元素的数据集合的时候比二叉树的高度小很多,IO次数也降低了很多~


    什么是B+树?

            了解完B树,再来看看B+树:

            如下图

            1.B+树的每个结点里可以有N个值,并且在分成N个区间 ;

            2.B树的每个结点的值不能重复出现,B+树则可能重复出现(父元素的值在子元素中会以最大值或者最小值的形式出现)。

            3.子叶中各结点是一链表的形式连接起来的,便于范围查找

            4.子叶是全集数据(每条记录完整关联到子叶上即可),而非子叶是只需要保存索引(目录)即可,非子叶占用空间相比于子叶这种完整数据集合占用的空间要小的多,就可以放在内存中缓存,查询就进一步减少了硬盘IO。

  • 相关阅读:
    产线工控安全有什么好的解决方案
    博弈论中的MinMax搜索算法
    [云原生] k8s之存储卷
    HttpClient,HttpClinet5的使用区别,以及上传文件使用区别。
    智源AI日报(2022-08-29): 2022谷歌博士奖学金名单公布:共61人获奖,新增推荐系统方向
    Django--31Django知识体系梳理总结
    黑鲨给电脑重装系统的详细步骤
    上海亚商投顾:三大指数小幅上涨 HBM概念股全天强势
    3. CDN 概念、作用和原理?
    Java中的final关键字,你清楚吗?
  • 原文地址:https://blog.csdn.net/CYK_byte/article/details/126438772
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号