MYSQL 中单id查询与IN查询,哪个效率更高?

例如:1:foreach($itemas$k=>$v){//循环100次//这里使用单id查询一条数据。}2:使用IN查询idIN(1,2,3,.......,100),... 例如:
1:foreach($item as $k=>$v){
//循环100次
//这里使用单id查询一条数据。
}
2:使用IN查询id IN(1,2,3,.......,100),100个id条件。
同样的结果,1个查询100次,1次查询1条数据;一个查询1次,1次查询100条数据,哪一个效率高些?
希望能帮我回答下,在下不胜感激!可以追加悬赏!
展开
 我来答
浴火fToG7
2011-12-20 · TA获得超过456个赞
知道小有建树答主
回答量:208
采纳率:0%
帮助的人:189万
展开全部
在查询效率上,是第一个快
但是在对服务器的io压力上,倾向于使用第二个
因为一次查询就是一次mysql链接,占一个磁盘io。而且mysql一般的链接数是2000.你这一循环就一下占100个链接,虽然不会那么夸张,但是如果是高并发的情况。。就不容乐观了。
所以推荐使用第二个。
amily1214
2011-12-20 · 超过13用户采纳过TA的回答
知道答主
回答量:105
采纳率:0%
帮助的人:41万
展开全部
第二种效率高些,但是100个数据不算明显吧,数据量越大越能看出来。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
迦楠
2011-12-21
知道答主
回答量:16
采纳率:0%
帮助的人:17.1万
展开全部
第二种方式,即用IN的方式效率更高一些,特别是在数据量更大的情况下更明显
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友ac581bedd
2011-12-21 · 超过36用户采纳过TA的回答
知道答主
回答量:158
采纳率:0%
帮助的人:97.7万
展开全部
in效率更高!多一个循环多一个查询,就多一次连接,这个相对于in来说耗资源一些。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
施家俊
2011-12-20 · TA获得超过324个赞
知道小有建树答主
回答量:919
采纳率:0%
帮助的人:384万
展开全部
自认为用IN快点
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式