MySQL-mysql in搜索和循环查询
场景:
假设有一个表A
有a,b,c,d四列。a为主键,b有hash索引且所有的行均不相同(为唯一值)。
我现在有20个b列的数据,我现在需要找出这20个数据对应的c列的相应数据。
问题:
1,mysql的in条件(where b in (b0,b1,b2,b3,b4.....b19))解析是怎么往出掳数据的?(是否遍历A表中的b列数据?还是遍历这20个数据?)
2,我循环这20个b数据从表中取数据性能高还是用in条件查询性能高?(多少数据量的时候哪个更好?)
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
1, 对这二十个数据排序, 每次做二分查找:
http://dev.mysql.com/doc/refman/5.6/en/comparison-operators.html#function_in
有索引的话, 也可能直接用这二十个数据去 按索引查.
2, 用in性能高.