子查询或内查询 《从实践中学习Oracle SQL 上 》 P140-160
1、标准范例
SQL> select *
2 from emp
3 where job=(select job from emp where ename='SMITH');
注意:
(1)子查询中不能包含group by 语句,因为此语句将返回多个值
(2)子查询未匹配到相应条件记录时,将返回零行,此时主查询的where子句判断将变成和NULL值比较,将返回“未选定行”。
2、having子句子查询
使得分组可以用于子查询中
SQL> select job,min(sal),max(sal),avg(sal)
2 from emp
3 group by job
4 having avg(sal)>(select min(avg(sal)) from emp group by job);
3、from 子句中子查询
SQL> select e.empno,e.ename,e.sal,e.job,a.avesal
2 from emp e,(select job,avg(sal) avesal from emp group by job) a
3 where e.job=a.job
4 and e.sal>a.avesal;
4、多行子查询 IN ANY ALL
注意:此列求每个职位工资最高的员工信息,如果不使用子查询,而单独用group by语句,将漏掉某一职位工资最高,但员工数目不止一个的人员
SQL> select *
2 from emp
3 where sal in(select max(sal) from emp group by job);
注意:
(1)IN()和=ANY()是相等的
(2)注意返回结果为null的问题
5、多列子查询
SQL> select *
2 from emp
3 where (sal,job) in (select max(sal),job from emp group by job);
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/27662838/viewspace-749599/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/27662838/viewspace-749599/