当前位置:主页   > 电脑数据库 > 正文
简述Oracle中in和exists的不同
来源:网络    作者:    时间:    
收藏此页】    【字号    】    【打印】    【关闭

一直以来,大家认为exists比in速度快,其实是不准确的。且看接下来的具体分析:in其实是将外表和内表进行hash join,exists是先对外表进行loop操作,然后每次loop后再对内表进行查询。

如果两张表大小差不多,那么exists和in的效率差不多。

例如: 一张大表为A,一张小表B

一、第一种情况


select * from A where mm in (select mm from B)

效率高,这里用到的是大表A上的索引


select * from B exists (select mm from A where mm=B.mm)

效率高,这里用到的是小表B上的索引

二、第二种情况


select * from B where mm in (select mm from A)

效率低,这里..

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明