mysql 中 in 大量 id 该怎样优化

2018-11-20 16:59:40 +08:00
 cc959798

比如 where id in (...),如果里面几条或者十几条还是很快的,但是我们需要一次查出上万条不同 id 的数据,该怎办,这时候 explain 显示的全表扫了

7997 次点击
所在节点    MySQL
26 条回复
lxerxa
2018-11-20 21:42:22 +08:00
@cc959798 原则上用 in 的又可以改成 exists
cc959798
2018-11-21 11:20:12 +08:00
@lxerxa 大佬,这种怎么改 select * from tb_name where id in (123,321,231) 就一张表
cc959798
2018-11-21 11:20:55 +08:00
@zhangZMZ 试过了也不管用,就是走索引,其实 id 间差距不大,走索引的话应该没什么问题
lxerxa
2018-11-21 11:54:59 +08:00
@lxerxa in 里的 id 来自哪里?同一个表吗? 不会告诉我是几个常量吧
zhangZMZ
2018-11-21 18:35:15 +08:00
目前看来这个问题的解决需要依赖于楼主是否是妹子,而且是否漂亮、有没有男朋友了。
cc959798
2018-11-21 18:54:20 +08:00
@lxerxa 这个是这样的前端传过来的 id 值,可能有很多,而且这个 id 就是这个表里的

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

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

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

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

© 2021 V2EX