为什么这句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?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
这篇关于索引条件下推写得不错,你可能参考下: https://www.cnblogs.com/zengk...
条件包含索引和未索引的列,优化器将首先解析索引的列,并在表中查找其他条件的行
如果我没猜错的话,tcid字段是这个表的主键吧。那加上order by语句后使用索引下推就说的过去了。
首先要明确,mysql的普通索引查询,是根据索引查找到主键索引,然后回表查询出全部数据。所以这里根据tname索引查找到结果以后,又根据主键索引order by 那么mysql会直接使用索引下推来对结果进行排序
我猜你去掉order by tcid 走的也是using index condition
因为select 星号 了 把星号改成tname试试