in 虽然和 or 有一定的区别,但单从整体逻辑和执行计划来看,相差无几,所以关于 in 的使用,宏观是可以看成(...or ...or......)
in : 把外表和内表作hash 连接
exists : 对外表作loop循环,每次loop循环再对内表进行查询
1. 如果查询的两个表大小相当,那么用in和exists差别不大;
2. 如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:
参考文献:
http://blog.sina.com.cn/s/blog_3edc5e2e0102uzjn.html
http://blog.itpub.net/28912557/viewspace-1255568/
IN与EXISTS性能对比
本文探讨了SQL查询中IN与EXISTS关键字的性能差异,分析了不同场景下两者的选择依据,并提供了具体的使用建议。
10万+

被折叠的 条评论
为什么被折叠?



