目录
一、索引类型
二、聚簇索引和非聚簇索引
三、覆盖索引
四、联合索引
最左前缀匹配原则
索引下推
五、唯一索引
首页 数据库 mysql教程 MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引是什么

MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引是什么

May 26, 2023 pm 04:37 PM
mysql

    一、索引类型

    索引根据底层实现可分为B-Tree索引和哈希索引,大部分时候我们使用的都是B-Tree索引,因为它良好的性能和特性更适合于构建高并发系统。

    根据索引的存储方式来划分,索引可以分为聚簇索引和非聚簇索引。非聚簇索引的叶子节点仅包含所有字段和主键ID,而聚簇索引的叶子节点则包含了完整的记录行。

    根据聚簇索引和非聚簇索引还能继续下分还能分为普通索引、覆盖索引、唯一索引以及联合索引等。

    二、聚簇索引和非聚簇索引

    聚簇索引也叫聚集索引,它实际上并不是一种单独的索引类型,而是一种数据存储方式,聚簇索引的叶子节点保存了一行记录的所有列信息。也就是说,聚簇索引的叶子节点中,包含了一个完整的记录行。

    非聚簇索引也叫辅助索引、普通索引,它的叶子节点只包含一个主键值,通过非聚簇索引查找记录要先找到主键,然后通过主键再到聚簇索引中找到对应的记录行,这个过程被称为回表。

    例如一个包含了用户姓名和年龄的的数据表,假设主键是用户ID,聚簇索引的结构为(橙色的代表id,绿色是指向子节点的指针):

    MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引是什么

    叶子节点中,为了突出记录,把(id, name, age)区分开来了,实际上是连在一起的,它们是构成一条记录的整体。

    而一个非聚簇索引(以age为索引)的结构是:

    MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引是什么

    除了年龄字段本身之外,在该节点的叶子节点中,仅包含当前记录的主键ID,而不包含完整记录的信息。需要通过id号到聚簇索引中进行回表查询才能获取整行记录数据。

    在InnoDB中,每张表必须有一个聚簇索引,默认情况下会根据主键建立。如果表中没有主键,InnoDB会选择一个合适的列作为聚簇索引,如果找不到合适的列,会使用一列隐藏的列DB_ROW_ID作为聚簇索引。

    三、覆盖索引

    非聚簇索引中因为不含有完整的数据信息,查找完整的数据记录需要回表,所以一次查询操作实际上要做两次索引查询。如果每个索引查询都需要进行两次才能获得结果,那么这一定会导致效率下降,因为能够减少一次查询就应该减少一次。

    以上面的age索引为例,它是一个非聚簇索引,如果我想通过年龄查询用户的id,执行了下面一条语句:

    1

    select id from userinfo where age = 10;

    这种情况是否还有必要去回表?因为我只需要id的值,通过age这个索引就已经能拿到id了,如果还去回表一次不就做了无用的操作了吗?实际上确实是不需要的。当辅助索引已经包含了所有查询所需的信息时,在索引查询中就可以避免回表操作,这就是覆盖索引。

    四、联合索引

    联合索引指的是同时对多列创建的索引,创建联合索引后,叶子节点会同时包含每个索引列的值,并且同时根据多列排序,这个排序和我们所理解的字典序类似。

    例如对同时对上面的姓名和年龄创建的索引结构:

    MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引是什么

    (name, age)都是简写,想不出十几个名字。

    每个叶子节点同时保存了所有的索引列,除此之外,还是只包含了主键id。

    最左前缀匹配原则

    当对多列创建索引后,并不是只要包含了创建索引的列就能使用索引,索引的使用要遵循最左前缀匹配原则。

    假设对列(A, B, C)创建索引,那么只有以下场景能使用索引:

    • 对列(A, B, C)/(A, C)或者(A, B)进行查询会匹配索引,对(C, A)或者(B, C)来说不能使用索引。

    • 通配符只能使用LIKE 'val%'形式,不能使用LIKE '%VAL%',后者会导致全表扫描。

    • 索引列不能进行运算,例如WHERE A + 1 = 5这种场景会导致索引失效。

    • 索引列不能包含范围值查询,如LIKE/BETWEEN/>/<等都会导致后面的列无法匹配索引。

    • 索引列不能包含有NULL值。

    索引下推

    新版本的MySQL(5.6以上)中引入了索引下推的机制:可以在索引遍历过程中,对索引中包含的字段先做判断,直接过滤掉不满足条件的记录,减少回表次数。

    例如针对上面表中的(name, age)做联合索引,正常情况下的查询逻辑:

    • 通过name找到对应的主键ID

    • 根据id记录的列匹配age条件

    这种做法会导致很多不必要的回表,例如表中存在(张三, 10)和(张三, 15)两条记录,此刻要查询(张三, 20)的记录。查询时先通过张三定位到所有符合条件的主键ID,然后在聚簇索引中遍历满足条件的行,看是否有符合age = 20的记录。在实际情况中,没有符合条件的记录,因此这个回表过程可以看作是无功之举。

    索引下推的主要功能就是改善这一点,在联合索引中,先通过姓名和年龄过滤掉不用回表的记录,然后再回表查询索引,减少回表次数。

    五、唯一索引

    唯一索引是一种不允许具有相同索引值的索引,系统在创建该索引时检查是否有重复的键值,每次对更新或增加记录时都会检查这一点。主键索引就是唯一索引。

    以上是MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

    本站声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门文章

    仓库:如何复兴队友
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌
    Hello Kitty Island冒险:如何获得巨型种子
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.能量晶体解释及其做什么(黄色晶体)
    1 周前 By 尊渡假赌尊渡假赌尊渡假赌

    热门文章

    仓库:如何复兴队友
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌
    Hello Kitty Island冒险:如何获得巨型种子
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.能量晶体解释及其做什么(黄色晶体)
    1 周前 By 尊渡假赌尊渡假赌尊渡假赌

    热门文章标签

    记事本++7.3.1

    记事本++7.3.1

    好用且免费的代码编辑器

    SublimeText3汉化版

    SublimeText3汉化版

    中文版,非常好用

    禅工作室 13.0.1

    禅工作室 13.0.1

    功能强大的PHP集成开发环境

    Dreamweaver CS6

    Dreamweaver CS6

    视觉化网页开发工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神级代码编辑软件(SublimeText3)

    PHP 的大数据结构处理技巧 PHP 的大数据结构处理技巧 May 08, 2024 am 10:24 AM

    PHP 的大数据结构处理技巧

    如何优化 PHP 中的 MySQL 查询性能? 如何优化 PHP 中的 MySQL 查询性能? Jun 03, 2024 pm 08:11 PM

    如何优化 PHP 中的 MySQL 查询性能?

    如何在 PHP 中使用 MySQL 备份和还原? 如何在 PHP 中使用 MySQL 备份和还原? Jun 03, 2024 pm 12:19 PM

    如何在 PHP 中使用 MySQL 备份和还原?

    如何使用 PHP 插入数据到 MySQL 表中? 如何使用 PHP 插入数据到 MySQL 表中? Jun 02, 2024 pm 02:26 PM

    如何使用 PHP 插入数据到 MySQL 表中?

    Java 枚举类型在数据库中的应用场景有哪些? Java 枚举类型在数据库中的应用场景有哪些? May 05, 2024 am 09:06 AM

    Java 枚举类型在数据库中的应用场景有哪些?

    如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 Dec 09, 2024 am 11:42 AM

    如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误

    如何在 PHP 中使用 MySQL 存储过程? 如何在 PHP 中使用 MySQL 存储过程? Jun 02, 2024 pm 02:13 PM

    如何在 PHP 中使用 MySQL 存储过程?

    PHP数组分页的性能优化策略 PHP数组分页的性能优化策略 May 02, 2024 am 09:27 AM

    PHP数组分页的性能优化策略

    See all articles