一、WHERE条件中的子查询

1. 比black工资高的雇员有哪些?

select ename

from emp

where sal>(select sal from emp where ename='BLAKE');

2. 高于30部门最高工资的雇员有哪些?

select ename,sal

from emp

where sal>(select max(sal) from emp where deptno=30);

select ename,sal

from emp

where sal > all (select sal from emp where deptno=10);   --任何

3. 当all后面接子查询的时候

"x = ALL (...)": The value must match all the values in the list to evaluate to TRUE.所有值都要匹配

"x != ALL (...)": The value must not match any values in the list to evaluate to TRUE.至少有一个值不匹配

"x > ALL (...)": The value must be greater than the biggest value in the list to evaluate to TRUE.大于最大的值

"x < ALL (...)": The value must be smaller than the smallest value in the list to evaluate to TRUE.小于最小的值

"x >= ALL (...)": The value must be greater than or equal to the biggest value in the list to evaluate to TRUE.大于等于最大的值

"x <= ALL (...)": The value must be smaller than or equal to the smallest value in the list to evaluate to TRUE.小于等于最小的值

4. 大于10部门最小工资的雇员有哪些?

select ename,sal

from emp

where sal> (select min(sal) from emp where deptno=10);

select ename,sal

from emp

where sal > any (select sal from emp where deptno=10);   --any 大于任何一个,那不就是最小的么??,任意一个

5. 当any后面接子查询的时候

"x = ANY (...)": The value must match one or more values in the list to evaluate to TRUE.至少匹配一个值

"x != ANY (...)": The value must not match one or more values in the list to evaluate to TRUE.一个值都不匹配

"x > ANY (...)": The value must be greater than the smallest value in the list to evaluate to TRUE.大于最小值

"x < ANY (...)": The value must be smaller than the biggest value in the list to evaluate to TRUE.小于最大值

"x >= ANY (...)": The value must be greater than or equal to the smallest value in the list to evaluate to TRUE.大于等于最小值

"x <= ANY (...)": The value must be smaller than or equal to the biggest value in the list to evaluate to TRUE.小于等于最大值

6. 工资最高的人是谁?

select ename from emp

where sal=(select max(sal) from emp);

7. 和ALLEN同部门,工资高于MARTIN的雇员有哪些?

select ename from emp

where deptno=(select deptno from emp where ename='ALLEN')

and sal>(select sal from emp where ename='MARTIN');

8. 工作和部门与SMITH相同,工资高于JAMES的雇员有哪些?

select ename from emp

where (job,deptno)=(select job,deptno from emp where ename='SMITH')

and sal>(select sal from emp where ename='JAMES');

二、FROM子句中的子查询

1. 工资高于本部门平均工资的人(拿上游工资的人)有哪些?

①求出每个部门的平均工资,把这个作为一张表

②使用emp表和平均工资表进行关联,

select ename,sal,avgsal,e.deptno

from emp e,

(select avg(sal) avgsal,deptno

from emp

group by deptno) b

where e.deptno=b.deptno

and e.sal>b.avgsal;

三、伪列:rownum

特点:先有结果集在有rownum,是对结果集的一个编号

1. 工资前五名的人?(TOP-N 分析)

①先把工资排序

②在使用rownum限结果集(为什么不在第一步就使用rownum限定结果集?执行顺序的问题,where要比order by先执行,获取rownum<6的时候还没来得及排序在从emp里面拿出来

select ename,sal

from emp

where sal in

(select sal

from (select distinct sal from emp order by sal desc)

where rownum<6)

order by sal desc;

3. 工资6~10的人?

①先把工资排序

②把工资排名在6~10的拿出来,由于不能使用rownum>6 and xxx<10这样,所以要加一步,把rownum变成id列,这样就又构造成一个结果集

③把上一个结果集中id为6~10的条目拿出来

④和emp关联

select ename,sal from emp

where sal in

(select sal from

(select rownum rn,sal

from (select distinct sal

from emp order by sal desc))

where rn between 6 and 10)

order by sal desc;

oracle如何使用子查询,Oracle-子查询相关推荐

  1. 怎样学好Oracle子查询,Oracle学习(六):子查询

    Oracle学习(6):子查询 子查询 为何要用子查询 SQL> --查询工资比SCOTT高的员工信息 SQL> --1. 知道SCOTT的工资 SQL> select sal fr ...

  2. oracle多表关联查询报表,oracle多表关联查询和子查询

    oracle多表关联查询和子查询 一.多表关联查询 例子: sql> create table student1 ( sid varchar(3), sname varchar(6), sage ...

  3. oracle复杂的子查询,Oracle 子查询(复杂select语句)

    在执行数据操作时,如果某个操作需要依赖于另外一个 select语句的查询结果,那么就可以把 select 语句迁入到该操作语句中,这样就形成了一个子查询.实际应用中,表与表之间相互关联,相互依存,这样 ...

  4. oracle 语句 子查询,Oracle子查询

    在本教程中,您将了解有助于构建更多可读查询的Oracle子查询,并可在不使用复杂联接或联合的情况下编写查询. Oracle子查询简介 子查询是嵌套在另一个语句(如SELECT,INSERT,UPDAT ...

  5. Oracle笔记(六) 多表查询、统计函数及分组查询、子查询

    本次预计讲解的知识点 1. 多表查询的操作.限制.笛卡尔积的问题: 2. 统计函数及分组统计的操作: 3. 子查询的操作,并且结合限定查询.数据排序.多表查询.统计查询一起完成各个复杂查询的操作: 一 ...

  6. oracle sql 转换成 hive sql -子查询转关联查询(三).子查询中嵌套子查询

    其他sql格式也在更新中,可直接查看俺的这个系列,要是没有你需要的格式,可在评论或私信我,俺现在一天一看 Oracle转换hive 其他sql格式也在更新中,可直接查看俺的这个系列,要是没有你需要的格 ...

  7. Oracle数据库SQL语句(四)—子查询(嵌套查询)

    Oracle数据库SQL语句(四) 子查询(嵌套查询) 1.单行子查询 SELECT * FROM stuWHERE ID > (SELECT ID FROM stu WHERE NAME =' ...

  8. oracle 找子表,oracle多表查询和子查询练习

    --1.列出至少有三个员工的所有部门和部门信息. SELECT D.DEPTNO, D.DNAME, D.LOC, T.COUNTS FROM DEPT D, (SELECT DEPTNO, COUN ...

  9. oracle左表关联与又表关联,oracle多表关联查询和子查询

    oracle多表关联查询和子查询 一.多表关联查询 例子: SQL> create tablestudent1 ( sidvarchar(3), snamevarchar(6), sagenum ...

  10. oracle 外键子查询,外键、联合查询、子查询

    1.外键: 增加外键 创建表的时候增加外键:在所有的表字段之后,使用foreign key(外键字段) references 外部表(主键字段) 在新增表之后增加外键:修改表结构,使用alter ta ...

最新文章

  1. 修改代码150万行!Apache Flink 1.9.0做了这些重大修改!(附链接)
  2. sqlserver创建存储过程、函数、
  3. top,right,bottom,left设置为0有什么用?
  4. java datainputstream_Java DataInputStream readUnsignedByte()方法
  5. Mac Book Pro不能识别移动硬盘
  6. 预览ExtJS 4.0的新功能(四):焕然一新的Store/Proxy
  7. 开源 java CMS - FreeCMS2.7 移动端栏目页静态化
  8. revit建筑样板_BIM技术在历史保护建筑中的具体应用(艾三维BIM分享)
  9. windows环境下安装TensorFlow(亲测)
  10. java语言的数据类型_Java语言的数据类型
  11. iconv linux 开源代码,每天一个 Linux 命令(123):iconv 命令
  12. 【重磅】2021年SCI影响因子滚烫式公布!各领域TOP期刊!(附下载链接)
  13. Doug Lea是谁?谁知道
  14. 虚拟机一直光标闪,进不去,解决方法之一。
  15. 程序员时事面试题——地震预测
  16. 51单片机用STC—ISP烧录程序是一直显示“正在检测目标单片机···”冷启动板子没有反应
  17. 数电基本触发器(全)
  18. Java使用freemarker生成word文件
  19. 对接企业微信会议室的会议管理系统解决方案
  20. C++画图之Go C编程 第1-9课(共53题)

热门文章

  1. 图像整合到文件中_整合图像和表格数据以进行深度学习
  2. 贪心 最大乘积 java_最大乘积|贪心算法|FOJ1698|TYVJ3024
  3. 机器学习实验之肿瘤分类与预测(朴素贝叶斯)
  4. 【Linux36-2】zabbix监控(mysql+percona+tomcat+主动式监控+onealert云告警)
  5. java vertx http_springboot-vertx
  6. 《长安十二时辰》愿你看尽世间百态,心中仍有热血
  7. 创意时尚美观 光电LED智能玻璃屏优势
  8. Shell | Hello World
  9. linux+ping网络脚本,使用ping命令检测整个网段IP的网络状态的shell脚本(图文)
  10. AVRCP@[1] AvrcpTargetService启动