搞懂MySQL聚集索引与非聚集索

一、前言

我们在开发或者面试的过程中经常会涉及到索引。今天我们来详细剖析一下索引常用的知识点。首先我们先介绍mysql的常用的存储引擎,其次是索引分类。

二、索引分类

MySQL 的索引有两种分类方式:逻辑分类和物理分类

三、逻辑分类

有多种逻辑划分的方式,比如按功能划分,按组成索引的列数划分等

3.1、功能划分

主键索引:一张表只能有一个主键索引,不允许重复、不允许为 NULL

主键索引:一张表只能有一个主键索引,不允许重复、不允许为 NULL

 ALTERTABLE TableName ADDPRIMARYKEY(column_list);

唯一索引:数据列不允许重复,允许为 NULL 值,一张表可有多个唯一索引,索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一

CREATE UNIQUE INDEX IndexName ON `TableName`(`字段名`(length));
# 或者
ALTERTABLE TableName ADD UNIQUE (column_list);

普通索引:一张表可以创建多个普通索引,一个普通索引可以包含多个字段,允许数据重复,允许 NULL 值插入;

CREATE INDEX IndexName ON `TableName`(`字段名`(length));
# 或者
ALTERTABLE TableName ADD INDEX IndexName(`字段名`(length));

全文索引:它查找的是文本中的关键词,主要用于全文检索

按列数划分

单列索引:一个索引只包含一个列,一个表可以有多个单例索引。

组合索引:一个组合索引包含两个或两个以上的列。查询的时候遵循 最左前缀原则

3.2、物理分类(重点)

聚簇索引

将数据存储与索引放到了一块,找到索引也就找到了数据

非聚簇索引

将数据与索引分开存储,索引结构的叶子节点指向了数据对应的位置

四、不同存储引擎中索引落盘的差异

存储引擎

MyISAM:

  • *.frm:与表相关的元数据信息都存放在frm文件,包括表结构的定义信息等
  • *.MYD:MyISAM DATA,用于存储MyISAM表的数据
  • *.MYI:MyISAM INDEX,用于存储MyISAM表的索引相关信息

InnoDB:

  • *.frm:与表相关的元数据信息都存放在frm文件,包括表结构的定义信息等
  • *.ibd:InnoDB DATA,表数据和索引的文件。该表的索引(B+树)的每个非叶子节点存储索引,叶子节点存储索引和索引对应的数据

五、假设用户(t_user)如下

id

name

gender

phone

1

Qin

1

181**

2

Jac

0

125**

3

Jam

1

199**

4

Mic

1

185**

5

Tom

1

147**

6

Sev

0

186**

六、聚集索引 (又叫聚簇索引)

主键索引

InnoDB只有一个文件(.ibd文件),那索引放在哪里呢?在InnoDB 里面,它是以主键为索引来组织数据的存储的,所以索引文件和数据文件是同一个文件,都在.ibd文件里面。在InnoDB的主键索引的叶子节点上,它直接存储了我们的数据。

辅助索引

假设在NAME列上创建一个索引,那name的索引B+ tree 如下

查询IO图形化表示如下:

主键索引与辅助索引配合查询

非聚集索引

主键索引

非聚集索引在叶节点上有一个“指针”直接指向要查询的数据区域

辅助索引

在MyISAM里面,辅助索引也在这个.MYI文件里面。辅助索引跟主键索引存储和检索数据的方式是没有任何区别的,一样是在索引文件里面找到磁盘地址,然后到数据文件里面获取数据。​

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/233836.html<

(0)
运维的头像运维
上一篇2025-04-20 19:44
下一篇 2025-04-20 19:45

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注