MySQL索引:聚集索引、非聚集索引、联合索引、回表、索引覆盖
一、聚集索引和非聚集索引
在MySql里,innodb通过主键构建一个B+树,该B+树用来存放数据(非叶子结点存放主键,叶子结点存放数据)。
如果不存在主键:MySql使用唯一索引,如果不存在唯一索引,那么就会创建一个隐式的RowId构建一个聚簇索引。
二、其它索引
除去主键索引,还有其它的索引,每个索引都会建立一个B+树,这些B+树是非聚集索引,非聚集索引,非叶子结点存放索引,叶子结点存放表ID。
三、回表
在通过索引查询的过程中,先通过索引查询到主键,然后再通过主键去主键索引构建的B+树获取数据,这就是一次回表操作,也就是一次索引B+树,一次主键索引B+树。
四、联合索引
联合索引一起构成一个B+树,也是非聚簇索引结构,大致是这样的:index(a,b)
从图中可以看出:结构是按照a排序的,再确定了a的值之后,再按照b排序。
如果不确定a的值,按照b的值查询,那么b的值会没有规律的出现在B+树的任意位置,这就导致组合索引失效。
五、索引覆盖
如果在由索引构建的B+树里有查询需要的数据,那么就需要回表操作,这就是索引覆盖。
上一篇:无
下一篇:binlog存放的内容是什么
相关文章
-
SQL基础知识
SQL基础知识
NEW个对象 2025-01-13
-
数据库死锁问题排查过程会遇到哪些问题?
数据库死锁问题排查过程会遇到哪些问题? 1、锁的是那个表 一般会有报警信息,根据报警信息可以获取到sql语句,然后根据sql获取锁的那张表。
NEW个对象 2024-10-24
-
MySQL索引:聚集索引、非聚集索引、联合索引、回表、索引覆盖
MySQL索引:聚集索引、非聚集索引、联合索引、回表、索引覆盖
NEW个对象 2024-10-03