mysql中什么是非聚簇索引?


本文摘自PHP中文网,作者coldplay.xixi,侵删。

mysql中非聚簇索引是索引的存储和数据的存储是分离的,也就是说找到了索引但没找到数据,需要根据索引上的值即主键再次回表查询,非聚簇索引也叫做辅助索引。

mysql中非聚簇索引是:

索引的存储和数据的存储是分离的,也就是说找到了索引但没找到数据,需要根据索引上的值(主键)再次回表查询,非聚簇索引也叫做辅助索引。

一个例子

下面我们创建了一个学生表,做三种查询,来说明什么情况下是聚簇索引,什么情况下不是。

1

2

3

4

5

6

7

8

create table student (

    id bigint,

    no varchar(20) ,

    name varchar(20) ,

    address varchar(20) ,

    PRIMARY KEY (`branch_id`) USING BTREE,

    UNIQUE KEY `idx_no` (`no`) USING BTREE

)ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;

相关学习推荐:mysql视频教程

第一种,直接根据主键查询获取所有字段数据,此时主键是聚簇索引,因为主键对应的索引叶子节点存储了id=1的所有字段的值。

1

select * from student where id = 1

第二种,根据编号查询编号和名称,编号本身是一个唯一索引,但查询的列包含了学生编号和学生名称,当命中编号索引时,该索引的节点的数据存储的是主键ID,需要根据主键ID重新查询一次,所以这种查询下no不是聚簇索引

1

select no,name from student where no = 'test'

第三种,我们根据编号查询编号(有人会问知道编号了还要查询?要,你可能需要验证该编号在数据库中是否存在),这种查询命中编号索引时,直接返回编号,因为所需要的数据就是该索引,不需要回表查询,这种场景下no是聚簇索引

1

select no from student where no = 'test'

总结:

主键一定是聚簇索引,MySQL的InnoDB中一定有主键,即便研发人员不手动设置,则会使用unique索引,没有unique索引,则会使用数据库内部的一个行的id来当作主键索引,其它普通索引需要区分SQL场景,当SQL查询的列就是索引本身时,我们称这种场景下该普通索引也可以叫做聚簇索引,MyisAM引擎没有聚簇索引。

以上就是mysql中什么是非聚簇索引?的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql中i/o出现错误问题原因及解决方案(附优化建议)

mysql优化的思路介绍

(mariadb)mysql数据类型和存储机制全面讲解

mysql中的事件调度基础学习教程

mysql数据库快速入门基础学习(经典教程)

mysql 怎么手动建表

mysql如何使用授权命令grant

关于mysql中sql mode的查看与设置

mysql登录报错提示error 1045 (28000)错误的解决方法(图文)

mysql如何用minus运算符?

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...