时间:2021-05-23
一直以来,大家认为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)效率低,这里用到的是小表B上的索引
select * from A exists (select mm from B where mm=A.mm)效率高,这里用到的是大表A上的索引
三、第三种情况
not exists 在使用时依然会用到表上的索引,但是not in会进行全盘扫描
因此,not exists 始终比not in 的效率高
四、第四种情况
in与==效果是相同的
总结
以上所述是小编给大家介绍的Oracle中in和exists的不同,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
exists和in的区别很小,几乎可以等价,但是sql优化中往往会注重效率问题,今天咱们就来说说exists和in的区别。exists语法:select&hel
本文简述了通过创建databaselink实现ORACLE跨数据库查询的方法1.配置本地数据库服务器的tnsnames.ora文件$vi$ORACLE_HOME
array_key_exists()定义和用法array_key_exists()函数判断某个数组中是否存在指定的key,如果该key存在,则返回true,否则
array_key_exists()函数判断某个数组中是否存在指定的key,如果key存在,则返回true,否则返回flasearray_key_exists(
1,exists和in的理解(参考)exists:如果子查询中包括某一行,那么就为TRUEin:如果操作数为TRUE等于表达式列表中的一个,那么就为TRUEex