子查询(嵌套子查询)

where子句:子查询返回结果为单行单列,单行多列,多行单列(往往使用in,any,all)操作符
having子句:子查询返回结果单行单列数据,同时为了使用统计函数操作
from子句:子查询返回结果为多行多列,可以按照一张数据表(临时表)的形式操作
select子句:了解即可,可以通过别的子句形式完成。
rownum子句:只能执行<=运算,不能执行>或者between and 区间的运算,与order by连用时,要先使用order by排序(建立个临时表)。
范例(where):


1.查询基本工资比ALLEN低的全部雇员信息
a.找到ALLEN的工资,返回一个单行单列的数据
b. 在where子句中里面使用子查询

select * from emp 
where sal>(select sal from emp where ename='ALLEN')

2.查询与雇员7566从事统一工作且领导相同的的全部雇员信息
a.找到7566的工作和领导,返回单行多列的数据
b.在where子句中里面使用子查询

select * from emp where (job,mgr)=(select job,mgr from emp where empno=7566)
and empno<>7566

3.查询工资与每个部门中最低工资相同的全部雇员信息
a.查出每个部门最低工资是多少,返回多行单列的数据。
b.用where子句(in)
c.如果在in中子查询返回值有NULL,那么不会影响,但如果是not in 中子查询有null,那么不会返回任何值,用nvl函数(nvl(mgr,100))

select * from emp where sal in 
(select  min(sal) from emp GROUP BY deptno)

4.空数据判断
在sql中提供了一个exists结构用于判断子查询是否有数据返回,如果子查询中有数据返回,则exists结构返回ture,反之返回false


范例(having)

having一定是结合group by子句一起使用的,其主要目的是分组后的信息再次过滤,而与where子句不同的是,having是在分组后,可以使用统计函数。

1.查询每个部门平均工资最高的的部门名称及平均工资(最高的平均工资,肯定是统计函数的嵌套)
a.先求出部门平均工资最高的那个平均工资,返回的是单行单列的数据

select  dname,avg(sal) from emp join dept on DEPT.DEPTNO=EMP.DEPTNO
GROUP BY dname having avg(sal) =(select max(avg(sal)) from emp GROUP BY deptno )

范例(from)

from子句的主要功能是确定数据来源,那么来源都属于数据表,只要是在from子句中出现的内容一般都是多行多列的子查询返回。

1.查询薪金比ALLEN或clark多的所有员工的编号,姓名,基本工资,部门名称,领导姓名,部门人数。
a.找出所需要的表
emp:员工的编号,姓名,基本工资
dept:部门名称
emp:领导姓名
emp:统计部门人数

select emp.empno,EMP.ename,EMP.SAL,DEPT.dname,s.ENAME,temp.tt
from emp,dept,emp s,(select deptno ,count(*) as tt from emp GROUP BY deptno) temp
where emp.sal>any
(select sal from emp where ename in('ALLEN','CLARK'))
and DEPT.DEPTNO=EMP.DEPTNO
and EMP.mgr=s.EMPNO
and EMP.deptno=temp.deptno

范例(select)
1.查询每个部门的编号,名称,位置,部门人数,平均工资

 select dept.deptno,loc,DNAME,
(select count(*)
from emp where EMP.DEPTNO=DEPT.DEPTNO group by deptno
  ) count,
(   select avg(sal)from emp where EMP.DEPTNO=DEPT.DEPTNO group by deptno
) avg
from DEPT

范例(rownum)
1.查询工作在CHICAGO并且入职日期最早的前2,名员工姓名,入职日期。

select b.hiredate,rownum from (select * from emp ORDER BY hiredate ) b
join dept on DEPT.DEPTNO=b.deptno where ROWNUM<3 and loc= 'CHICAGO'

分页查询

  • 目标页数*每页记录数
  • (目标页数-1)*每页记录数
    1.每页6条记录,查询第45页高工最高的员工姓名,工资,入职日期,所在部门.
select r,ename,hiredate,sal,dname
from (select rownum r,deptno,ename,hiredate,sal   from (select * from emp ORDER BY sal DESC) 
where rownum<=45*6 ) s,dept where r>(45-1)*6 and DEPT.DEPTNO=s.deptno

练习
1.查询工资高于编号7782的员工工资,并且和7396号员工工作相同的员工编号,姓名,工资。

select sal,ename,empno
from emp 
where sal>(select sal from emp where EMPNO=7782)
and job=(select job from emp where empno=7369)

2.查询工资最高的员工姓名,和工资。

select ename ,sal from emp 
where sal=(select max(sal) from emp )

3.查询部门工资高于10号部门最低工资的部门编号,部门名称,及部门最低工资。

 select emp.deptno,dname,min(sal)
from emp,DEPT
where EMP.DEPTNO=dept.DEPTNO 
GROUP BY emp.deptno,dname having min(sal)<( 
select min(sal) from emp where deptno=10)

4.查询员工工资为其部门最低工资的员工编号和姓名及工资。

select ename,sal,empno from emp where sal in(
select min(sal) from emp GROUP BY deptno)

5.显示经理是KING的员工姓名,工资。

select ename,sal from emp 
where mgr=(select empno from emp where ename='KING')

6.显示比员工SMITH参加工作是时间晚的员工姓名,工资,参加工作的时间。

 select ename,sal,hiredate from emp where hiredate>
(select hiredate from emp where ename='SMITH')

7.使用子查询方式查询那些职员在NEW YORK工作。

select ename from emp where deptno=(select deptno from dept where loc='NEW YORK')

8.写一个查询显示和员工SMITH工作在同一个部门的员工的姓名,日期,不包括SMITH。

select ename,hiredate from emp where deptno=
(select deptno from emp where ename='SMITH')
and ename<>'SMITH'

9.写一个查询显示其工资比全体职员平均工资高的员工编号,姓名。

select ename,empno from emp where sal>
(select avg(sal) from emp)

10.查询显示上级领导是KING的员工,姓名
同第五题
11.显示所有工作在RESEARCH部门的员工姓名,职位。

select ename,job from emp join dept on dept.DEPTNO=EMP.DEPTNO
where dname='RESEARCH'

12.查询每个部门的部门编号,平均工资,要求部门平均工资大于20号部门的平均工资。

select deptno,avg(sal) from emp  GROUP BY deptno HAVING avg(sal)>(
select avg(sal) from emp where deptno=20)

13.查询大于自己部门平均工资的员工姓名,工资,所在部门平均工资,高于部门平均工资的额度。

select ename,sal,avg from emp,
(select deptno ,avg(sal) as avg  from emp GROUP BY deptno) temp
where EMP.DEPTNO=TEMP.DEPTNO
and sal>avg

14.列出至少有一个雇员的所有部门。

select deptno from emp
GROUP BY DEPTNO
having count(*)>=1

15.列出薪金比'SMITH'多的所有雇员。

select ename from emp where sal>(select sal from emp 
where ename='SMITH')

16.列出入职日期早于其直接上级的所有雇员。

select EMP.ename 
from emp join emp temp 
on EMP.mgr=TEMP.empno
where  EMP.HIREDATE<TEMP.HIREDATE

17.找员工姓名和直接上级姓名。

select EMP.ename,TEMP.ename 
from emp join emp temp
on EMP.MGR=TEMP.EMPNO

18.显示每个部门的最高工资的员工。

select ename from emp where sal 
in(select max(sal) from emp GROUP BY DEPTNO )

19.显示工资最高的员工参加工作时间晚的员工姓名,参加工作时间。

select ename,hiredate from emp 
where hiredate >(select hiredate from emp where sal=(select max(sal)from emp ))

20.显示每位经理管理员工的最低工资,及最低工资者的姓名。

a.SELECT ename,sal from emp 
where (sal,mgr) in (SELECT min(SAL),mgr from emp  GROUP BY mgr)
b.Select e.ename,e.sal From emp e,(select min(sal) mins
 from emp group by mgr having mgr is not null) a where e.sal=a.mins;

21.显示平均工资最高部门的平均部门名称及平均工资。

a.
select  DEPT.dname ,avg(sal)
from dept join emp on DEPT.DEPTNO=EMP.DEPTNO GROUP BY DEPT.dname  having avg(sal)=(
select  max(avg(sal)) from emp GROUP BY DEPTNO)


b.
select dept.dname,TEMPTAB2.MAXSAL
from
(select max(tempTab.avgsal) maxsal
from 
(select DEPTNO,avg(sal) avgsal
from EMP
GROUP BY DEPTNO) tempTab) tempTab2
join 
(select DEPTNO,avg(sal) avgsal
from EMP
GROUP BY DEPTNO) tempTab3 on tempTab2.MAXSAL = tempTab3.AVGSAL
join dept on dept.deptno = tempTab3.deptno
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容

  • where子句:子查询返回结果为单行单列,单行多列,多行单列(往往使用in,any,all)操作符having子句...
    李哈哈_bing阅读 2,548评论 0 4
  • 引出 •请思考如下问题? –查询所有员工的每个月工资总和,平均工资? –查询工资最高和最低的工资是多少? –查询公...
    C_cole阅读 7,284评论 0 3
  • 目标 聚合函数 分组函数 子查询 多行子查询 引出 •请思考如下问题? –查询所有员工的每个月工资总和,平均工资?...
    wqjcarnation阅读 4,146评论 0 6
  • 笔记: 一、聚合函数:计数 最大值 最小值 平均数 求和 1.计数 COUNT() 忽略NULL值 方式1:COU...
    凤之鸠阅读 5,203评论 0 1
  • 这是一个没有音乐的夜晚 甚至,没有任何声音 但我知道你在 你无声的脚步 和 往事一同敲击我心的门 你是我一生...
    阿木讷言阅读 341评论 1 4