子查询sql语句及注意问题

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值