高级子查询

作者: 辽A丶孙悟空 | 来源:发表于2019-02-15 08:49 被阅读12次
一、嵌套子查询
  • 在通常的子查询中,子查询是以嵌套的方式写在父查询的WHERE、HAVING、FROM子句中,所以被称为嵌套子查询。
  • 嵌套子查询的执行过程
    • 子查询首先执行一次
    • 用来自子查询的值确认或取消父查询的候选行
  • 嵌套子查询的写法
  • 例如:
SELECT empno, ename, sal 
FROM emp e,(SELECT deptno,avg(sal) avgsal 
            FROM emp 
            GROUP BY deptno) d 
WHERE e.deptno =d.deptno 
AND e.sal >d.avgsal;
二、相关子查询
  • 相关子查询是当子查询中引用了父查询表中的一个列时,Oracle服务器会执行相关子查询。
  • 相关子查询的执行过程

1.取得父查询的候选行
2.用候选行被子查询引用列的值执行子查询
3.用来自查询的值确认或取消候选行
4.重复1、2、3,直到父查询中无剩余的候选行

  • 相关子查询的写法

-例如:

SELECT empno,ename,sal,deptno 
FROM emp outer 
WHERE sal >   
           (SELECT AVG(sal)
            FROM  emp 
            WHERE deptno  =  outer.deptno) ;
三、EXISTS和NOT EXISTS操作符
  • 相关子查询还可以使用EXISTS和NOT EXISTS操作符来进行操作。
  • EXISTS 判断是否“存在”,具体操作如下:
  • 子查询中如果有记录找到,子查询语句不会继续执行,返回值为TRUE
  • 子查询中如果得到表的结尾都没有记录找到,返回值为FALSE
  • EXISTS子查询并没有确切的记录返回,只是判断是否有记录存在,而且只要是找到相关记录,子查询就不需要继续执行,然后再进行下面的操作。这样大大提高了语句的执行效率。
  • NOT EXSITS正好相反,判断子查询是否没有返回值。如果没有返回值,认为表达式为真,如果找到一条返回值,则为假。
  • 例如:查询哪些人不是经理
SELECT ename,job,sal,deptno 
FROM emp e 
WHERE NOT EXISTS (SELECT '1' 
                  FROM emp 
                  WHERE mgr= e.empno);
   //注意:因为NOT  EXSITS子句中,没有明确的返回值,
   //只返回真和假,所以不会返回空值,
   //即不用考虑子查询中去掉空值的问题。这是它与NOT IN的区别。
  • 查询哪些人是经理
SELECT ename,job,sal,deptno 
FROM emp e 
WHERE EXISTS (SELECT  '1' 
              FROM emp 
              WHERE mgr=  e.empno);
   //注意:因为EXISTS子句中,没有明确的返回值,只返回真或假,
   //所以‘1’就是个占位符,没有实际的意义。

相关文章

  • SQL查询_高级查询

    SQL查询_高级查询 一、子查询 子查询出现的位置一般为条件语句,oracle会先执行子查询,再执行父查询,子查询...

  • 高级子查询

    练习1.1 查询比所在职位平均工资高的员工姓名,职位。 1.2 查询工资为其部门最低工资的员工编号,姓名,工资。 ...

  • 高级子查询

    查询比所在职位平均工资高的员工姓名,职位。 查询工资为其部门最低工资的员工编号,姓名,工资。 查询哪些员工是经理 ...

  • 高级子查询

    一、嵌套子查询 在通常的子查询中,子查询是以嵌套的方式写在父查询的WHERE、HAVING、FROM子句中,所以被...

  • 17/12/11高级子查询

    17/12/11高级子查询 嵌套子查询:在通常的子查询中,子查询是以嵌套的方式写在父查询的WHERE、HAVING...

  • 高级子查询(相关子查询)

    (先看外部表,先选取外部表的第一行,用它的列与内部表的条件进行相连查询)1.查询比所在职位平均工资高的员工姓名,职...

  • 高级子查询(相关子查询)

    (先看外部表,先选取外部表的第一行,用它的列与内部表的条件进行相连查询)1.查询比所在职位平均工资高的员工姓名,职...

  • MySQL 学习 Part7 - MySQL子查询和连接表

    ? MySQL的子查询和连接表以及高级连接表的使用? 兼顾工作和考试实在是太累了 1.子查询语句 1.子查询 需求...

  • SQL语言之查询

    SQL语言之查询(二) 前言 本章我们将学习SQL查询中的高级部分,如内连接、外连接和子查询,通过这些查询技术我们...

  • 03随风而逝

    写写今天学到的知识, 简单,少。 《mysql必知必会》:有 子查询,联结表,高级联结,组合查询,插入数据,更新和...

网友评论

    本文标题:高级子查询

    本文链接:https://www.haomeiwen.com/subject/oqnueqtx.html