在子查询中,NOT IN子句将执行一个内部的排序和合并. 无论在哪种情况下,NOT IN都是最低效的 (因为它对子查询中的表执行了一个全表遍历).  为了避免使用NOT IN ,我们可以把它改写成外连接(Outer Joins)或NOT EXISTS.

 例如:

SELECT …

FROM EMP

WHERE DEPT_NO NOT IN (SELECT DEPT_NO

                         FROM DEPT

                         WHERE DEPT_CAT=’A’);

为了提高效率.改写为:

 (方法一: 高效)

SELECT ….

FROM EMP A,DEPT B

WHERE A.DEPT_NO = B.DEPT(+)

AND B.DEPT_NO IS NULL

AND B.DEPT_CAT(+) = ‘A’

 (方法二: 最高效)

SELECT ….

FROM EMP E

WHERE NOT EXISTS (SELECT ‘X’

                    FROM DEPT D

                    WHERE D.DEPT_NO = E.DEPT_NO

                    AND DEPT_CAT = ‘A’);

相关文章:

  • 2022-12-23
  • 2021-10-16
  • 2022-12-23
  • 2021-05-14
  • 2022-12-23
  • 2021-11-12
  • 2021-12-09
  • 2021-12-09
猜你喜欢
  • 2021-11-03
  • 2021-10-01
  • 2022-12-23
  • 2021-05-21
  • 2022-12-23
  • 2022-01-19
  • 2018-02-07
相关资源
相似解决方案