永发信息网

SQL中IN和EXISTS用法的区别

答案:1  悬赏:50  手机版
解决时间 2021-03-18 20:58
SQL中IN和EXISTS用法的区别
最佳答案
. 用EXISTS替代IN、用NOT EXISTS替代NOT IN
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接.在这种情况下, 使用EXISTS(或NOT EXISTS)通常将提高查询的效率. 在子查询中,NOT IN子句将执行一个内部的排序和合并. 无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执行了一个全表遍历). 为了避免使用NOT IN ,我们可以把它改写成外连接(OUTER JOINS)或NOT EXISTS.
例子:(高效)SELECt * FROM EMP (基础表) WHERe EMPNO > 0 AND EXISTS (SELECt ‘X' FROM DEPT WHERe DEPT.DEPTNO = EMP.DEPTNO AND LOC = ‘MELB’)
(低效)SELECt * FROM EMP (基础表) WHERe EMPNO > 0 AND DEPTNO IN(SELECt DEPTNO FROM DEPT WHERe LOC = ‘MELB’)
12. 用EXISTS替换DISTINCT
当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECt子句中使用DISTINCT. 一般可以考虑用EXIST替换, EXISTS 使查询更为迅速,因为RDBMS核心模块将在子查询的条件一旦满足后,立刻返回结果。
例:(低效): SELECT DISTINCT DEPT_NO,DEPT_NAME FROM DEPT D , EMP E WHERe D.DEPT_NO = E.DEPT_NO
(高效): SELECt DEPT_NO,DEPT_NAME FROM DEPT D WHERe EXISTS ( SELECt ‘X' FROM EMP E WHERe E.DEPT_NO = D.DEPT_NO);
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
从浙江衢州到河南漯河怎么走啊!坐火车要多长
大磨脑营地址有知道的么?有点事想过去
民事纠缠我改出示什么相关证据
明锐1.6自动档,车子一打火平均油耗显示20-30
樊文化面膜武乡有没有
脆皮猪脚火锅地址在哪,我要去那里办事
蓝莓怎么做成蓝莓酱好呢
求个 绝命时刻 五星之光的注册表
1999年05月05号出生那一年是18周岁
怎么才能让我在全民k歌的人气一下子上涨
FD是什么意思啊?求大神帮助
怎么去除膏药贴痕
房县到神农架路线地图导航
事业单位中级职称8级和9级档案工资一样吗
福乐家居生活馆地址有知道的么?有点事想过去
推荐资讯
常州火车站走到汽车站要多久时间啊? 晚上8点
《士兵突击》在钢七连改编后,许三多和钢七连
黄道十二宫是哪个文明首先提出的
找不到放光盘的地方。。。
兴牧兽药我想知道这个在什么地方
时代轻卡气刹刹车右偏怎么办
求萧亚轩一首歌的歌名,歌词是爱的太逞强,无
自从搬家后身体为什么今这样明天那样自从搬家
医院院长恶意骂员工。拖欠员工工资怎么投诉
国家药监局药品查询腰椎痹痛丸国药准字z44023
内屏坏了有哪些现象
为什么要提高审美能力
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?