码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 索引(含B树、B+树)


    1、索引(index)

    索引是在数据库表的字段上添加的,是为了提高查询效率存在的一种机制。
    一张表的一个字段可以添加一个索引,当然,多个字段联合起来也可以添加索引。
    索引相当于一本书的目录,是为了缩小扫描范围而存在的机制。

    索引检索(效率高):先通过目录(索引)去定位一个大概的位置,然后直接定位到这个位置,做局部性扫描,缩小扫描范围,快速查找

    如果某个字段(name字段)没有添加索引(目录),或者说没有name字段创建索引,MySQL会进行全扫描,会将name字段上的每个值都比对一遍

    MySQL:1、全表扫描;2、根据索引检索

    2、索引结构

    B树——多路平衡查找树
    以最大度数为5的B树为例:

    树的度数:一个节点的子节点个数。

    每个节点有4个key,5个指针
    为什么4个key,有5个指针?
    比如:key(4):20,30,62,89
    那么:指针(5):<20,20-30,30-62,62-89,>89

    中间元素向上分裂

    B树:所有节点存放key-value
    B+树:所有数据都会出现在叶子节点;叶子节点形成一个单向链表

    MySQL索引结构对经典的B+树进行优化,在原B+树的基础上,增加了一个指向相邻叶子节点的链表指针,就形成了带有顺序指针的B+树。变成了循环双向链表

    3 索引分类

    聚集索引

    必须有,且只有一个:数据存储和索引放在一块,索引结构的叶子节点保存了行数据

    二级索引

    可以存在多个:数据存储和索引分开,索引结构的叶子节点关联的是对应的主键

    存在主键,主键索引就是聚集索引
    没有主键,第一个唯一索引就是聚集索引
    没有主键也没有唯一索引,InnoDB存储引擎自动生成rowid作为隐藏的聚集索引。

    回表查询:根据二级索引找到主键值,再根据主键值根据聚集索引拿到行数据

    索引使用原则

    最左前缀法则

  • 相关阅读:
    LeetCode——Weekly Contest 319
    C语言c89(c90)的所有的32个关键字分类
    学生DW静态网页设计——html+css+javascript+jquery+bootstarp马尔代夫旅游响应式网站
    人工智能轨道交通行业周刊-第63期(2023.10.9-10.15)
    科创人·望繁信创始人索强:中国版流程挖掘注定有完全不同的活法
    TCP/IP(十五)拥塞控制
    Apache Zookeeper 未授权访问漏洞【原理扫描】
    JAVA实现智能停车场管理系统 开源
    nginx能干什么?
    JSP自定义标签(foreach标签与select标签的自定义方式)
  • 原文地址:https://blog.csdn.net/m0_60641871/article/details/132502411
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号