• SQL嵌套SELECT语句的用法-


    SQL嵌套SELECT语句是很常见的SQL语句,下面就为您详细介绍SQL嵌套SELECT语句的语法,并附相关示例,供您参考学习之用。

    嵌套SELECT语句也叫子查询,一个SELECT 语句的查询结果能够作为另一个语句的输入值。子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select list中,作为一个字段值来返回。

    1、单行子查询 :单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。

    例:

    1. select ename,deptno,sal   
    2. from emp   
    3. where deptno=(select deptno from dept where loc='NEW YORK');  

    2、多行子查询:多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可("IN" 操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL 和ANY 操作符不能单独使用,而只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用。

    例:

    1).多行子查询使用IN操作符号例子:查询选修了老师名叫Rona(假设唯一)的学生名字

    1. sql> select stName  
    2.  
    3. from Student  
    4.  
    5. where stId in(selectdistinct stId from score where teId=(select teId from teacher where teName='Rona'));  

    查询所有部门编号为A的资料:

    1. SELECT ename,job,sal  
    2.  
    3. FROM EMP  
    4.  
    5. WHERE deptno in ( SELECT deptno FROM dept WHERE dname LIKE 'A%');  

    2).多行子查询使用ALL操作符号例子:查询有一门以上的成绩高于Kaka的最高成绩的学生的名字:

    1. sql> select stName  
    2.  
    3. from Student  
    4.  
    5. where stId in(select distinct stId from score where score >all(select score from score where stId=(select stId from Student where stName= 'Kaka') ));  

    3). 多行子查询使用ANY操作符号例子:查询有一门以上的成绩高于Kaka的任何一门成绩的学生的名字:

    1. sql> select stName  
    2.  
    3. from Student  
    4.  
    5. where stId in(select distinct stId from score where score >any(select score from score where stId=(select stId from Student where stName='Kaka')));  

    3、多列子查询:当是单行多列的子查询时,主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较;当是多行多列子查询时,主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。

    例:

    1. SELECT deptno,ename,job,sal   
    2. FROM EMP   
    3. WHERE (deptno,sal) IN (SELECT deptno,MAX(sal) FROM EMP GROUP BY deptno);  

    4、内联视图子查询

    例:

    1. (1)SELECT ename,job,sal,rownum   
    2. FROM (SELECT ename,job,sal FROM EMP ORDER BY sal);   
    3. (2)SELECT ename,job,sal,rownum   
    4. FROM ( SELECT ename,job,sal FROM EMP ORDER BY sal)   
    5. WHERE rownum<=5;  

    5、在HAVING子句中使用子查询

    例:

    1. SELECT deptno,job,AVG(sal) FROM EMP GROUP BY deptno,job HAVING AVG(sal)>(SELECT sal FROM EMP WHERE ename='MARTIN'); 
  • 相关阅读:
    MFC画图(画线、画矩形、画刷画笔的使用)
    VC保证应用程序只有一个实例在运行
    MFC字体(一)(控件文字字体)
    获得当前程序路径
    CDC,CPaintDC,CClientDC,CWindowDC
    vc写csv文件
    【MFC学习】之CFileDialog
    MFC集合类的使用
    MFC字体(二)(控件字体颜色)
    键盘事件响应
  • 原文地址:https://www.cnblogs.com/hushzhang/p/5286038.html
Copyright © 2020-2023  润新知