当前位置: 首页 > news >正文

三十三、【进阶】索引的分类

1、索引的分类

(1)总分类

主键索引、唯一索引、常规索引、全文索引

(2)InnoDB存储引擎中的索引分类

2、 索引的选取规则(InnoDB存储引擎)

如果存在主键,主键索引就是聚集索引;

如果不存在主键,将使用第一个“唯一(UNIQUE)索引”作为聚集索引;

如果表没有主键,并且没有合适的唯一索引,那么InnoDB存储引擎将自动生成一个rowid作为隐藏的聚集索引;

3、说明

(1)聚集索引(由主键构成):

如果一张表有主键,主键构建的主键索引就是一个聚集索引,其将会构成一个B+树。

根据聚集索引的结构,叶子节点下挂着的数据,就是该主键所对应的行数据。

(2)二级索引(name字段):

当以“name”字段建立一个索引时,也是以B+树的形式存储其节点,其叶子节点下挂着的数据,是其所在行的“聚集索引”,如name=‘Ruby’,其叶子节点下挂着的数据,就是“id=8”。

(3) 执行流程解释:

当执行如下语句时:

select * from user where name="Arm";

首先,找到“Arm”,然后找到“Arm”下面挂着的id,发现id=10,然后(在关于id字段的B+树中)找到id=10,最后输出其下挂着的数据。

http://www.lryc.cn/news/186887.html

相关文章:

  • VBox启动失败、Genymotion启动失败、Vagrant迁移
  • 一篇短小精悍的文章让你彻底明白KMP算法中next数组的原理
  • CSS盒子定位的扩张
  • SpringBoot整合POI实现Excel文件读写操作
  • 从零开始的力扣刷题记录-第八十七天
  • 【1】c++设计模式——>UML类图的画法
  • SAP UI5 指定 / 变更版本
  • SpringMVC中异常处理详解
  • PPT课件培训视频生成系统实现全自动化
  • Densenet--->比残差力度更大 senet-->本质抑制特征
  • 基于腾讯云的OTA远程升级
  • 如何在VS2022中进行调试bug,调试的快捷键,debug与release之间有什么区别
  • 初识jmeter及简单使用
  • Spring 在多线程环境下如何确保事务一致性
  • [Machine Learning] Learning with Noisy Data
  • C++中有哪些常用的标准库?
  • 软考-信息安全工程师概述
  • 2023-2024年华为ICT网络赛道模拟题库
  • 英特尔参与 CentOS Stream 项目
  • Centos 服务器 MySQL 8.0 快速开启远程访问
  • 充电保护芯片TP4054国产替代完全兼容DP4054DP4054H 锂电充电芯片
  • Java Spring Boot中的爬虫防护机制
  • 状态模式 行为型模式之六
  • JAVA NIO深入剖析
  • 企业电子招投标系统源码之电子招投标系统建设的重点和未来趋势
  • 基于正点原子alpha开发板的第三篇系统移植
  • 数据结构与算法设计分析——贪心算法的应用
  • Leetcode 2895. Minimum Processing Time
  • 学信息系统项目管理师第4版系列21_范围管理
  • threejs 透明贴图,模型透明,白边