非聚簇索引一定会回表查询吗?
不一定,这涉及到查询语句所要求的字段是否全部命中了索引,如果全部命中了索引,那么不需要进行回表查询。
例如,在学生表的年龄上建立了索引
CREATE INDEX sc_age ON sc(age)
查看sc的表结构
desc sc
当进行explain select age from sc where age<20查询时,在索引的叶子节点上已经包含了age信息,不会再次进行回表查询。
欢迎批评指正,提出问题,谢谢!
不一定,这涉及到查询语句所要求的字段是否全部命中了索引,如果全部命中了索引,那么不需要进行回表查询。
例如,在学生表的年龄上建立了索引
CREATE INDEX sc_age ON sc(age)
查看sc的表结构
desc sc
当进行explain select age from sc where age<20查询时,在索引的叶子节点上已经包含了age信息,不会再次进行回表查询。