简述Oracle中in和exists的不同
发布时间:2020-12-12 17:08:41 所属栏目:百科 来源:网络整理
导读:一直以来,大家认为exists比in速度快,其实是不准确的。且看接下来的具体分析:in其实是将外表和内表进行hash join,exists是先对外表进行loop操作,然后每次loop后再对内表进行查询。 如果两张表大小差不多,那么exists和in的效率差不多。 例如: 一张大表
一直以来,大家认为exists比in速度快,其实是不准确的。且看接下来的具体分析:in其实是将外表和内表进行hash join,exists是先对外表进行loop操作,然后每次loop后再对内表进行查询。 如果两张表大小差不多,那么exists和in的效率差不多。 例如: 一张大表为A,一张小表B 一、第一种情况效率高,这里用到的是大表A上的索引 效率高,这里用到的是小表B上的索引 二、第二种情况效率低,这里用到的是小表B上的索引 效率高,这里用到的是大表A上的索引 三、第三种情况not exists 在使用时依然会用到表上的索引,但是not in会进行全盘扫描 因此,not exists 始终比not in 的效率高 四、第四种情况in与==效果是相同的 总结 以上所述是小编给大家介绍的Oracle中in和exists的不同,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程之家网站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |