博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ORACLE in与exists语句的区别(一)
阅读量:6905 次
发布时间:2019-06-27

本文共 1447 字,大约阅读时间需要 4 分钟。

(转载:https://www.cnblogs.com/iceword/archive/2011/02/15/1955337.html)

select * from A

where id in(select id from B)

以上查询使用了in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表的id是否与B表中的id相等,如果相等则将A表的记录加入结果集中,直到遍历完A表的所有记录.

它的查询过程类似于以下过程

List resultSet=[];

Array A=(select * from A);
Array B=(select id from B);

for(int i=0;i<A.length;i++) {

   for(int j=0;j<B.length;j++) {
      if(A[i].id==B[j].id) {
         resultSet.add(A[i]);
         break;
      }
   }
}
return resultSet;

可以看出,当B表数据较大时不适合使用in(),因为它会B表数据全部遍历一次.

如:A表有10000条记录,B表有1000000条记录,那么最多有可能遍历10000*1000000次,效率很差.
再如:A表有10000条记录,B表有100条记录,那么最多有可能遍历10000*100次,遍历次数大大减少,效率大大提升.

结论:in()适合B表比A表数据小的情况

select a.* from A a

where exists(select 1 from B b where a.id=b.id)

以上查询使用了exists语句,exists()会执行A.length次,它并不缓存exists()结果集,因为exists()结果集的内容并不重要,重要的是结果集中是否有记录,如果有则返回true,没有则返回false.

它的查询过程类似于以下过程

List resultSet=[];

Array A=(select * from A)

for(int i=0;i<A.length;i++) {

   if(exists(A[i].id) {    //执行select 1 from B b where b.id=a.id是否有记录返回
       resultSet.add(A[i]);
   }
}
return resultSet;

当B表比A表数据大时适合使用exists(),因为它没有那么遍历操作,只需要再执行一次查询就行.

如:A表有10000条记录,B表有1000000条记录,那么exists()会执行10000次去判断A表中的id是否与B表中的id相等.
如:A表有10000条记录,B表有100000000条记录,那么exists()还是执行10000次,因为它只执行A.length次,可见B表数据越多,越适合exists()发挥效果.
再如:A表有10000条记录,B表有100条记录,那么exists()还是执行10000次,还不如使用in()遍历10000*100次,因为in()是在内存里遍历比较,而exists()需要查询数据库,我们都知道查询数据库所消耗的性能更高,而内存比较很快.

结论:exists()适合B表比A表数据大的情况

当A表数据与B表数据一样大时,in与exists效率差不多,可任选一个使用.

转载于:https://www.cnblogs.com/meditator/p/7942649.html

你可能感兴趣的文章
华为敏捷/DevOps实践:产品经理如何开好迭代计划会议
查看>>
随记之oracle查询某字段某几位的条件 substr
查看>>
saltstack之(十)扩展组件salt-ssh
查看>>
MySQL 8.0.11(zip)安装及配置
查看>>
postgresql----条件表达式
查看>>
sql server复制表数据到另外一个表 的存储过程
查看>>
wamp多网站配置for window 本地测试 单Ip
查看>>
蓝桥杯 k倍区间(前缀和问题)
查看>>
Spring指定扫描包时不包含的类或包含的类
查看>>
js技巧-使用reduce实现更简洁的数组对象去重和数组扁平化
查看>>
赵教授的课程
查看>>
iOS 中正确切换摄像头&正确实现设置帧率的方式
查看>>
sas数组,数组的语法与一些特殊定义,获取维度大小
查看>>
Alpha版总结会议
查看>>
“恶意”权限总结
查看>>
九省LNOI2018退役记
查看>>
mysql 索引
查看>>
分类算法优劣谈——pycharm无法安装sklearn2的包,sklearn的包无法识别各种算法
查看>>
【总结整理】webGIS学习
查看>>
网页颜色代码对照(转)
查看>>