zoukankan      html  css  js  c++  java
  • Oracle学习(六):子查询

    1.知识点:能够对比以下的录屏进行阅读

    SQL> --子查询所要解决的问题:问题不能一步求解
    SQL> --查询工资比SCOTT高的员工信息
    SQL> --(1)使用普通方法
    SQL> --1. SCOTT的工资
    SQL> select sal from emp where ename='SCOTT';
    SQL> --2. 查询比3000高的员工
    SQL> select *
      2  from emp
      3  where sal>3000;
    SQL> --(2)使用子查询
    SQL> select *
      2  from emp
      3  where sal > (select sal
      4               from emp
      5               where ename='SCOTT');
    
    SQL> -- 注意的问题:
    SQL> --1. 将子查询放入括号里
    SQL> --2. 採用合理的书写风格
    SQL> --3. 能够在主查询的where ,select 。from ,having后面。放置子查询
    SQL> --4. 不能够在group by后面放置子查询
    SQL> --5. 强调from后面放置子查询
    SQL> --6. 主查询和子查询能够不是同一张表,仅仅要子查询返回的结果。主查询能够使用。就可以
    SQL> --7. 一般不在子查询中使用order by;但在Top-N分析问题中。必须使用order by
    SQL> --8. 一般先运行子查询,再运行主查询;但相关子查询除外
    SQL> --9. 单行子查询仅仅能使用单行操作符;多行子查询仅仅能使用多行操作符
    SQL> --10. 注意子查询中null
    
    SQL> --部分注意问题举例
    SQL> --3. 能够在主查询的where select from having后面,放置子查询
    SQL> --select
    SQL> select ename,sal,(select job from emp where empno=7839) myjob
      2  from emp;
    
    SQL> --5. 强调from后面放置子查询
    SQL> --查询员工的姓名和薪水
    SQL> select *
      2  from (select ename,sal from emp);
    
    
    SQL> --6. 主查询和子查询能够不是同一张表。仅仅要子查询返回的结果,主查询能够使用,就可以
    SQL> --查询部门名称为 SALES的员工信息
    SQL> --子查询
    SQL> select *
      2  from emp
      3  where deptno=(select deptno
      4                from dept
      5                where dname='SALES');
    SQL> --多表查询
     SQL> select e.*
      2  from emp e,dept d
      3  where e.deptno=d.deptno and d.dname='SALES';
    SQL> --SQL优化: 假设子查询和多表查询都能够,理论上尽量使用多表查询
    
    SQL> --多行操作符
    SQL> --in :在集合中
    SQL> --查询部门名称为SALES和ACCOUNTING的员工信息
    SQL> select *
      2  from emp
      3  where deptno in (select deptno from dept where dname='SALES' or dname='ACCOUNTING');
    SQL> --使用多表查询
    SQL> select e.*
      2  from emp e,dept d
      3  where e.deptno=d.deptno and (d.dname='SALES' or d.dname='ACCOUNTING');
    
    SQL> --any :和集合的随意一个值比較
    SQL> --查询工资比30号部门随意一个员工高的员工信息
    SQL> select *
      2  from emp
      3  where sal > any (select sal from emp where deptno=30);
    SQL> --单行子查询的方法也能够解决问题
    SQL>select *
      2  from emp
      3  where sal > (select min(sal) from emp where deptno=30)
    
    SQL> --all :和集合的全部值比較
    SQL> --查询工资比30号部门全部员工高的员工信息
    SQL> select *
      2  from emp
      3  where sal > all (select sal from emp where deptno=30);
    SQL> --单行子查询的方法也能够解决问题
    SQL> select *
      2  from emp
      3  where sal > (select max(sal) from emp where deptno=30)
    
    SQL> --多行子查询中null值问题
    SQL> --集合中有null值不能使用not in,但能够使用in
    SQL> --查询不是老板的员工信息
    SQL> select *
      2  from emp
      3  where empno not in (select mgr from emp);		--此查询没有结果,由于含有空值
    SQL> --查询是老板的员工信息
    SQL> select *
      2  from emp
      3  where empno in (select mgr from emp);	--此查询结果正常
    SQL> --原因:全部和空值比較的条件结果是空;
    SQL> --使用not in方法的正确语句
    SQL> select *
      2  from emp
      3  where empno not in (select mgr from emp where mgr is not null);

    2.在Sqlplus下实际运行的结果录屏:

    SQL> --查询工资比SCOTT高的员工信息
    SQL> --1. SCOTT的工资
    SQL> select sal from emp where ename='SCOTT';
    
           SAL                                                                      
    ----------                                                                      
          3000                                                                      
    
    SQL> --查询比3000高的员工
    SQL> set linesize 120
    SQL> col sal for 9999
    SQL> select *
      2  from emp
      3  where sal>3000;
    
         EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                   
    ---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                   
          7839 KING       PRESIDENT            17-11月-81      5000                    10                                   
    
    SQL> --子查询所要解决的问题:问题不能一步求解
    SQL> select *
      2  from emp
      3  where sal > (select sal
      4               from emp
      5               where ename='SCOTT');
    
         EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                   
    ---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                   
          7839 KING       PRESIDENT            17-11月-81      5000                    10                                   
    
    SQL> /*
    SQL> 注意的问题:
    SQL> 1. 将子查询放入括号里
    SQL> 2. 採用合理的书写风格
    SQL> 3. 能够在主查询的where select from having后面。放置子查询
    SQL> 4. 不能够在group by后面放置子查询
    SQL> 5. 强调from后面放置子查询
    SQL> 6. 主查询和子查询能够不是同一张表,仅仅要子查询返回的结果。主查询能够使用,就可以
    SQL> 7. 一般不在子查询中使用order by;但在Top-N分析问题中,必须使用order by
    SQL> 8. 一般先运行子查询,再运行主查询;但相关子查询除外
    SQL> 9. 单行子查询仅仅能使用单行操作符。多行子查询仅仅能使用多行操作符
    SQL> 10. 注意子查询中null
    SQL> */
    SQL> --3. 能够在主查询的where select from having后面,放置子查询
    SQL> --select
    SQL> select ename,sal,(select job from emp where empno=7839) myjob
      2  from emp;
    
    ENAME        SAL MYJOB                                                                                                  
    ---------- ----- ---------                                                                                              
    SMITH        800 PRESIDENT                                                                                              
    ALLEN       1600 PRESIDENT                                                                                              
    WARD        1250 PRESIDENT                                                                                              
    JONES       2975 PRESIDENT                                                                                              
    MARTIN      1250 PRESIDENT                                                                                              
    BLAKE       2850 PRESIDENT                                                                                              
    CLARK       2450 PRESIDENT                                                                                              
    SCOTT       3000 PRESIDENT                                                                                              
    KING        5000 PRESIDENT                                                                                              
    TURNER      1500 PRESIDENT                                                                                              
    ADAMS       1100 PRESIDENT                                                                                              
    
    ENAME        SAL MYJOB                                                                                                  
    ---------- ----- ---------                                                                                              
    JAMES        950 PRESIDENT                                                                                              
    FORD        3000 PRESIDENT                                                                                              
    MILLER      1300 PRESIDENT                                                                                              
    
    已选择14行。
    
    SQL> --5. 强调from后面放置子查询
    SQL> --查询员工的姓名和薪水
    SQL> select *
      2  from (select ename,sal from emp);
    
    ENAME        SAL                                                                                                        
    ---------- -----                                                                                                        
    SMITH        800                                                                                                        
    ALLEN       1600                                                                                                        
    WARD        1250                                                                                                        
    JONES       2975                                                                                                        
    MARTIN      1250                                                                                                        
    BLAKE       2850                                                                                                        
    CLARK       2450                                                                                                        
    SCOTT       3000                                                                                                        
    KING        5000                                                                                                        
    TURNER      1500                                                                                                        
    ADAMS       1100                                                                                                        
    
    ENAME        SAL                                                                                                        
    ---------- -----                                                                                                        
    JAMES        950                                                                                                        
    FORD        3000                                                                                                        
    MILLER      1300                                                                                                        
    
    已选择14行。
    
    SQL> --6. 主查询和子查询能够不是同一张表,仅仅要子查询返回的结果。主查询能够使用。就可以
    SQL> --查询部门名称为 SALES的员工信息
    SQL> select *
      2  from emp
      3  where deptno=(select deptno
      4                from emp
      5                where dname='SALES');
                  where dname='SALES')
                        *
    第 5 行出现错误: 
    ORA-00904: "DNAME": 标识符无效 
    
    
    SQL> ed
    已写入 file afiedt.buf
    
      1  select *
      2  from emp
      3  where deptno=(select deptno
      4                from dept
      5*               where dname='SALES')
    SQL> /
    
         EMPNO ENAME      JOB              MGR HIREDATE         SAL       COMM     DEPTNO                                   
    ---------- ---------- --------- ---------- -------------- ----- ---------- ----------                                   
          7499 ALLEN      SALESMAN        7698 20-2月 -81      1600        300         30                                   
          7521 WARD       SALESMAN        7698 22-2月 -81      1250        500         30                                   
          7654 MARTIN     SALESMAN        7698 28-9月 -81      1250       1400         30                                   
          7698 BLAKE      MANAGER         7839 01-5月 -81      2850                    30                                   
          7844 TURNER     SALESMAN        7698 08-9月 -81      1500          0         30                                   
          7900 JAMES      CLERK           7698 03-12月-81       950                    30                                   
    
    已选择6行。

    SQL> select e.* 2 from emp e,dept d 3 where e.deptno=d.deptno and d.dname='SALES'; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7900 JAMES CLERK 7698 03-12月-81 950 30 已选择6行。 SQL> --SQL优化: 假设子查询和多表查询都能够,理论上尽量使用多表查询 SQL> host cls SQL> --多行操作符 SQL> --in :在集合中 SQL> --查询部门名称为SALES和ACCOUNTING的员工信息 SQL> select * 2 from emp 3 where deptno in (select deptno from dept where dname='SALES' or dname='ACCOUNTING'); EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7900 JAMES CLERK 7698 03-12月-81 950 30 7934 MILLER CLERK 7782 23-1月 -82 1300 10 已选择9行。

    SQL> select e.* 2 from emp e,dept d 3 where e.deptno=d.deptno and (d.dname='SALES' or d.dname='ACCOUNTING'); EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7900 JAMES CLERK 7698 03-12月-81 950 30 7934 MILLER CLERK 7782 23-1月 -82 1300 10 已选择9行。

    SQL> host cla SQL> host cls SQL> --any 和集合的随意一个值比較 SQL> --查询工资比30号部门随意一个员工高的员工信息 SQL> select * 2 from emp 3 where sal > any (select sal from emp where deptno=30); EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7839 KING PRESIDENT 17-11月-81 5000 10 7902 FORD ANALYST 7566 03-12月-81 3000 20 7788 SCOTT ANALYST 7566 13-7月 -87 3000 20 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7934 MILLER CLERK 7782 23-1月 -82 1300 10 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7876 ADAMS CLERK 7788 13-7月 -87 1100 20 已选择12行。

    SQL> ed 已写入 file afiedt.buf 1 select * 2 from emp 3* where sal > (select min(sal) from emp where deptno=30) SQL> / EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7788 SCOTT ANALYST 7566 13-7月 -87 3000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7876 ADAMS CLERK 7788 13-7月 -87 1100 20 7902 FORD ANALYST 7566 03-12月-81 3000 20 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7934 MILLER CLERK 7782 23-1月 -82 1300 10 已选择12行。

    SQL> --all 和集合的全部值比較 SQL> --查询工资比30号部门全部员工高的员工信息 SQL> select * 2 from emp 3 where sal > all (select sal from emp where deptno=30); EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7788 SCOTT ANALYST 7566 13-7月 -87 3000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7902 FORD ANALYST 7566 03-12月-81 3000 20 SQL> ed 已写入 file afiedt.buf 1 select * 2 from emp 3* where sal > (select max(sal) from emp where deptno=30) SQL> / EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7788 SCOTT ANALYST 7566 13-7月 -87 3000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7902 FORD ANALYST 7566 03-12月-81 3000 20 SQL> host cls SQL> --多行子查询中null值 SQL> --查询不是老板的员工信息 SQL> select * from emp; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7369 SMITH CLERK 7902 17-12月-80 800 20 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7788 SCOTT ANALYST 7566 13-7月 -87 3000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7876 ADAMS CLERK 7788 13-7月 -87 1100 20 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7900 JAMES CLERK 7698 03-12月-81 950 30 7902 FORD ANALYST 7566 03-12月-81 3000 20 7934 MILLER CLERK 7782 23-1月 -82 1300 10 已选择14行。 SQL> select * 2 from emp 3 where empno not in (select mgr from emp); 未选定行 SQL> --查询是老板的员工信息 SQL> ed 已写入 file afiedt.buf 1 select * 2 from emp 3* where empno in (select mgr from emp) SQL> / EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7902 FORD ANALYST 7566 03-12月-81 3000 20 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7839 KING PRESIDENT 17-11月-81 5000 10 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7788 SCOTT ANALYST 7566 13-7月 -87 3000 20 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 已选择6行。

    SQL> select * 2 from emp 3 where empno not in (select mgr from emp where mgr is not null); EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ---------- 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7934 MILLER CLERK 7782 23-1月 -82 1300 10 7369 SMITH CLERK 7902 17-12月-80 800 20 7876 ADAMS CLERK 7788 13-7月 -87 1100 20 7900 JAMES CLERK 7698 03-12月-81 950 30 已选择8行。

    SQL> spool off



  • 相关阅读:
    js怎么通过逗号将string转换成数组
    设置mysql数据库为只读
    python 关于django 2.X from django.contrib.auth.views import login
    python Django2.X,报错 ‘learning_logs ’is not a registered namespace,如何解决?
    python django2.x报错No module named 'django.core.urlresolvers'
    python Django2.0如何配置urls文件
    VMware vSphere 组件和功能
    VMware vSphere Client的简单使用教程
    python 逻辑运算 ‘and’ ,'or' 在实战中的作用,代替if语句。
    python_urllib2:urlerror和httperror
  • 原文地址:https://www.cnblogs.com/yjbjingcha/p/7028775.html
Copyright © 2011-2022 走看看