SQL中IN和EXISTS用法的区别
答案:1 悬赏:50 手机版
解决时间 2021-03-18 20:58
- 提问者网友:玫瑰园
- 2021-03-18 07:55
SQL中IN和EXISTS用法的区别
最佳答案
- 五星知识达人网友:空山清雨
- 2021-03-18 09:27
. 用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);
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接.在这种情况下, 使用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);
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯