子查询
- 查询里面嵌套查询,子查询需要用括号括起来,先执行子查询再执行主查询
- 子查询的结果就可以当成一个条件来使用
1.非相关的子查询
a. 单行子查询
例:在表EMP中查询所有工资高于JONES的所有雇员姓名、工作和工资
第一步)
select 雇员姓名、工作和工资
from emp
where sal > (JONES的工资);
第二步)
JONES的工资:
select sal from emp where ename = ‘JONES’;
第三步 完整写法)
select ename, job, sal
from emp
where sal > (select sal from emp where ename = ‘JONES’)
例:查询和KING在一个部门的员工信息
select *
from emp
where deptno = (select deptno from emp where ename = ‘KING’);
例:查询和scott在同一年但是不同月份入职的员工
select * from emp
–where 年份 = (scott的入职年份) and 月份 <> (scott的月份);
where
to_char(hiredate,‘yyyy’) = (select to_char(hiredate,‘yyyy’) from emp where ename = ‘SCOTT’)
AND
to_char(hiredate,‘MM’) != (select to_char(hiredate,‘MM’) from e