为什么这句sql使用了using index condition?

explain SELECT * FROM teacher WHERE tname = "张三" order by tcid
tname上建立了索引
没有order by tcid时候,extra为null
有order by tcid时候用了using index condition

如果这个sql是explain SELECT * FROM teacher WHERE tname > "张三" order by tcid
使用了using index condition我能理解,如果只是tname = "张三",只是用索引定位到数据,并没有筛选

因为 explain SELECT * FROM teacher WHERE tname = "张三"时候并没有using where,所以并没有筛选

我的问题是:explain SELECT * FROM teacher WHERE tname = "张三" order by tcid 为何使用到了 using index condition?

阅读 10.2k
4 个回答
新手上路,请多包涵

条件包含索引和未索引的列,优化器将首先解析索引的列,并在表中查找其他条件的行

如果我没猜错的话,tcid字段是这个表的主键吧。那加上order by语句后使用索引下推就说的过去了。
首先要明确,mysql的普通索引查询,是根据索引查找到主键索引,然后回表查询出全部数据。所以这里根据tname索引查找到结果以后,又根据主键索引order by 那么mysql会直接使用索引下推来对结果进行排序

我猜你去掉order by tcid 走的也是using index condition
因为select 星号 了 把星号改成tname试试

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏