博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle select in/exists/not in/not exits
阅读量:4068 次
发布时间:2019-05-25

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

in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。

一直以来认为exists比in效率高的说法是不准确的。
如果查询的两个表大小相当,那么用in和exists差别不大。
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。
一直以来认为exists比in效率高的说法是不准确的。
如果查询的两个表大小相当,那么用in和exists差别不大。

如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:

例如:表A(小表),表B(大表)

1:
select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;
select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。
相反的
2:
select * from B where cc in (select cc from A)
效率高,用到了B表上cc列的索引;
select * from B where exists(select cc from A where cc=B.cc)
效率低,用到了A表上cc列的索引。
not in 和not exists
如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;
而not extsts 的子查询依然能用到表上的索引。
所以无论那个表大,用not exists都比not in要快。

in 与 =的区别

select name from student where name in ('zhang','wang','li','zhao');

select name from student where name='zhang' or name='li' or name='wang' or name='zhao'

的结果是相同的。

-----------------------------------------------------------------实例
--登陆gather/123456@pc150 执行以下语句,注意执行时间
---小表
er_street_code
select distinct tt.gkdm from er_street_code tt where tt.gkdm is not null
---大表
er_in_detail,er_reck_detail

---例1

select * from er_reck_detail t1 where t1.gkdm in (select gg.gkdm from er_street_code gg)

select * from er_reck_detail t1 where exists (select * from er_street_code gg where t1.gkdm=gg.gkdm)

---例2

select * from er_street_code aa where aa.gkdm in (select mm.gkdm from er_reck_detail mm)

select * from er_street_code aa where exists (select * from er_reck_detail mm where mm.gkdm=aa.gkdm)

---例3

select * from er_reck_detail t1 where t1.gkdm in (select t2.gkdm from er_in_detail t2)

select * from er_reck_detail t1 where exists (select * from er_in_detail t2 where t1.gkdm=t2.gkdm)

本篇文章来源于:开发学院    原文链接:http://edu.codepub.com/2009/0721/10539.php

转载地址:http://zzaji.baihongyu.com/

你可能感兴趣的文章
Android/Linux 内存监视
查看>>
Android2.1消息应用(Messaging)源码学习笔记
查看>>
剑指offer算法题分析与整理(三)
查看>>
JVM并发机制探讨—内存模型、内存可见性和指令重排序
查看>>
nginx+tomcat+memcached (msm)实现 session同步复制
查看>>
WAV文件解析
查看>>
WPF中PATH使用AI导出SVG的方法
查看>>
QT打开项目提示no valid settings file could be found
查看>>
android 代码实现圆角
查看>>
java LinkedList与ArrayList迭代器遍历和for遍历对比
查看>>
drat中构造方法
查看>>
JavaScript的一些基础-数据类型
查看>>
coursesa课程 Python 3 programming 统计文件有多少单词
查看>>
coursesa课程 Python 3 programming course_2_assessment_7 多参数函数练习题
查看>>
coursesa课程 Python 3 programming course_2_assessment_8 sorted练习题
查看>>
多线程使用随机函数需要注意的一点
查看>>
getpeername,getsockname
查看>>
Visual Studio 2010:C++0x新特性
查看>>
所谓的进步和提升,就是完成认知升级
查看>>
如何用好碎片化时间,让思维更有效率?
查看>>