MYSQL的in条件查询其效率怎么样,有没有好的查询优化方案?(具体的使用场景在里面叙述了)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MYSQL的in条件查询其效率怎么样,有没有好的查询优化方案?(具体的使用场景在里面叙述了),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1385字,纯文字阅读大概需要2分钟。
内容图文
![MYSQL的in条件查询其效率怎么样,有没有好的查询优化方案?(具体的使用场景在里面叙述了)](/upload/InfoBanner/zyjiaocheng/237/2888777c9bc6439ea9845d95584e5918.jpg)
具体的sql语句大概就是:
select photo.* from photo where userId in(1,2,3,.........)
in条件里面就是我的好友。这是提前查询出来的。
这里有一个迷惑,就是假设我的好友有1000个,会不会查询的效率就慢了呢?
我不知道那些开源的PHP SNS是咋做的。。
各位大神应该都用过人人把!
我人人上面有接近1000个好友。那么,人人这个好友分享是咋做的呢?
也是select in
这种方式么?
回复内容:
在我的APP中,有一个类似于威信朋友圈那样的功能。就是能查看好友的分享。
具体的sql语句大概就是:
select photo.* from photo where userId in(1,2,3,.........)
in条件里面就是我的好友。这是提前查询出来的。
这里有一个迷惑,就是假设我的好友有1000个,会不会查询的效率就慢了呢?
我不知道那些开源的PHP SNS是咋做的。。
各位大神应该都用过人人把!
我人人上面有接近1000个好友。那么,人人这个好友分享是咋做的呢?
也是select in
这种方式么?
索引+分页+ajax自动加载
现在很多用nosql来实现,例如redis 的set集合,以为集合提供了丰富的交并集操作,所以实现起来很方面,这是个案例http://blog.nosqlfan.com/html/2938.html
新浪微博大量使用redis来做业务处理,网上有很多讲解的文章可以参照下。
你可以用redis 关注 好友等关键词来google下, 应该有很多结果。
加了索引不会太慢,或者你可以试试union
好多用的nosql
还可以用exists,比如:
select photo.* from photo p where exists (select 1 from user u where u.id = p.userId )
如果photo表数据量比user表数据量大的话,建议用in,反之,用exists比较快。
内容总结
以上是互联网集市为您收集整理的MYSQL的in条件查询其效率怎么样,有没有好的查询优化方案?(具体的使用场景在里面叙述了)全部内容,希望文章能够帮你解决MYSQL的in条件查询其效率怎么样,有没有好的查询优化方案?(具体的使用场景在里面叙述了)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。