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

发布于 2022-09-11 20:19:49 字数 497 浏览 45 评论 0

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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

满栀 2022-09-18 20:19:49

这篇关于索引条件下推写得不错,你可能参考下: https://www.cnblogs.com/zengk...

万水千山粽是情ミ 2022-09-18 20:19:49

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

世态炎凉 2022-09-18 20:19:49

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

万劫不复 2022-09-18 20:19:49

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文