为什么 MySQL 的 IN 操作在大于 3 个操作数时不用索引?

2020-08-16 14:14:46 +08:00
 changwei

突然发现这个很奇怪的现象

V2 贴图太麻烦了,我就直接知乎上提了个问题然后贴个传送门在下面,各位要回答的也可以去知乎回答

https://www.zhihu.com/question/414646774

其他 Oracle 和 sql server 我没用过,如果各位有环境的也可以试试看其他关系数据库是否也有这个问题

1449 次点击
所在节点    问与答
3 条回复
wakzz
2020-08-16 14:22:46 +08:00
mysql 的索引选择是基于成本计算的,你数据量太少,mysql 发现使用 in 操作使用主键索引需要三次回表的成本,比直接全表扫描的成本高,所以就直接使用全表扫描了。
chihiro2014
2020-08-16 15:08:13 +08:00
具体看查询优化器和成本模型是怎么弄的
bear2000
2020-08-16 19:01:43 +08:00
MySQL 优化器认为不用索引更快

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/698683

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX