【MySQL】索引的分类

举报
Laura_张 发表于 2022/08/27 22:36:18 2022/08/27
【摘要】 浅浅的了解一下索引的各种分类以及索引是如何创建和删除的。 【正文】 一、索引的分类 MySQL的索引包括普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。 ● 从功能逻辑上说,索引主要...

浅浅的了解一下索引的各种分类以及索引是如何创建和删除的。

【正文】

一、索引的分类

MySQL的索引包括普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。
● 从功能逻辑上说,索引主要有 4 种,分别是普通索引、唯一索引、主键索引、全文索引。
● 按照物理实现方式,索引可以分为 2 种:聚簇索引和非聚簇索引。
● 按照作用字段个数进行划分,分成单列索引和联合索引。

1. 普通索引

在创建普通索引时,不附加任何限制条件,只是用来提高查询效率。这类索引可以创建在任何数据类型中,其值是否唯一和非空,要由字段本身的完整性约束条件决定。建立索引后,可以通过索引进行查询,例如,在表student的字段name上建立一个普通索引,查询记录时就可以根据该索引进行查询。

2. 唯一性索引

使用UNIQUE参数可以设置索引为唯一性索引,在创建唯一性索引时,限制该索引的值必须是唯一的,但允许有空值,在一张数据表里可以有多个唯一索引。

3. 主键索引

主键索引就是一种特殊的唯一性索引,在唯一索引的基础上增加了不为空的约束,也就是NOT NULL+UNIQUE 一张表里最多只有一个主键索引

为什么,这是由主键索引的物理实现方式决定的,因为数据存储在文件中只能按照一种顺序进行存储。

4. 单列索引

在表中的单个字段上创建索引,单列索引只根据该字段进行索引,单列索引可以是普通索引,也可以是唯一性索引,还可以是全文索引,主要保证该索引只对应一个字段即可,一个表可以有多个单列索引。

5. 多列(组合、联合)索引

多列索引是在表的多个字段组合上创建一个索引。该索引指向创建时对应的多个字段,可以通过这几个字段进行查询,但是只有查询条件中使用了这些字段中的第一个字段时才会使用。

例如:在表中的字段Id name和gender上建立一个多列索引 idx_id_name_gender,只有在查询条件中使用了字段Id时该索引才会被使用,使用组合索引时遵循最左前缀集合。

6. 全文索引

在这里插入图片描述

7. 补充:空间索引

小结:不同的存储引擎支持的索引类型也不一样 :
InnoDB :支持 B-tree、Full-text 等索引,不支持 Hash索引;
MyISAM : 支持 B-tree、Full-text 等索引,不支持 Hash 索引;
Memory :支持 B-tree、Hash 等索引,不支持 Full-text 索引;
NDB :支持 Hash 索引,不支持 B-tree、Full-text 等索引;
Archive :不支持 B-tree、Hash、Full-text 等索引;

文章来源: blog.csdn.net,作者:张艳伟_Laura,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/Laura__zhang/article/details/125495349

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。