Oracle子查询

这里写目录标题

  • 子查询
  • 子查询的分类
    • 1.非相关子查询
      • 单行单列
      • 单行多列
      • 单列多行
      • 多行多列
    • 2.相关子查询

子查询

定义:一个查询语句中嵌套一个或多个查询语句,里层的查询语句的结果成为了外层查询语句的一部分。
外层的查询叫主查询
里层的查询叫子查询
子查询需要加括号

子查询的分类

1.非相关子查询

是指子查询部分,能单独运行,子查询不会牵扯主查询内容。主查询在乎的是子查询的结果。
根据子查询返回的结果不同,可以分为四种。

单行单列

SELECT AVG(sal) FROM emp;

例题:查询和SMITH在同一部门的员工信息。

SELECT * FROM emp WHERE deptno=(SELECT deptno FROM emp where ename='SMITH')

步骤:1.先写好主查询,子查询部分先用汉语表达,越清楚越好,如

SELECT * FROM emp WHERE deptno = (SMITH的部门编号)

2.写出子查询的查询,为了实现第一步中的汉语部分,查询结果列的个数,顺序,属性要和主查询条件列一致。

SELECT deptno FROM emp WHERE ename = 'SMITH'

3.将主查询和子查询结合。

SELECT * FROM emp WHERE deptno=(SELECT deptno FROM emp where ename='SMITH')

在这里插入图片描述

练习:查询和scott在同一岗位的员工信息

SELECT *FROM emp where job = (SELECT job FROM emp WHERE ename = 'SCOTT');

在这里插入图片描述

单行多列

不是很友好,用的不多
例题:查询和SOCTT在同一部门并且岗位也相同的员工信息。

SELECT * FROM emp WHERE (dept,job)=(SCOTT的部门和岗位)
--SCOTT的部门和岗位
SELECT deptno,job FROM emp WHERE ename = 'SCOTT';
--注意,查询的列的个数顺序属性要和主查询条件一致。
SELECT * FROM emp WHERE (deptno,job)=(SELECT deptno,job FROM emp WHERE ename = 'SCOTT')

练习:查询和scott或者king在同一部门并且同一岗位的员工信息

SELECT * FROM emp WHERE (deptno,job) in (SELECT deptno,job FROM emp WHERE ename in('SCOTT','KING'));

单列多行

把单列多行的查询结果看成一个集合
IN,ANY,ALL后面通常可以放结合
例题:查询和SMITH或者和KING在同一部门的员工信息

SELECT * FROM emp WHERE deptno IN (SELECT deptno FROM emp WHERE ename = 'SMITH' OR ename = 'KING');

练习:查询出emp表所有的领导信息。

SELECT * FROM emp WHERE empno in (SELECT  MGR FROM emp);

在这里插入图片描述

多行多列

子查询的结果相当于 一张表
大多数把多行多列的查询结果放在FROM关键字后面
例题:查询十号部门中最高的工资的员工。

SELECT ename,MAX(sal) FROM (SELECT sal,ename From emp WHERE deptno = 10 )

练习:查询所有部门中平均工资最高的部门编号

SELECT deptno FROM emp WHere (SELECT avg(sal) FROM emp GROUP by deptno )

习题:查询所有部门中平均工资最高的部门编号–把每个部门的平均工资当成表

方法1:
SELECT DEPTNOFROM (SELECT AVG(SAL) SAL, DEPTNO FROM EMP GROUP BY DEPTNO)WHERE SAL = (SELECT MAX(AVG(SAL)) SAL FROM EMP GROUP BY DEPTNO);
方法2:
SELECT DEPTNO, AVG(SAL)FROM EMPGROUP BY DEPTNO
HAVING AVG(SAL) = (SELECT MAX(SAL)FROM (SELECT AVG(SAL) SAL, DEPTNOFROM EMPGROUP BY DEPTNO));

2.相关子查询

是指子查询不能单独运行,子查询会牵扯主查询的部分内容
主查询在乎的是与子查询的关系。
例题
查询员工的姓名岗位薪资部门编号以及对应的部门名称。

SELECT ename,job,deptno,(对应部门编号的部门名称) FROM emp;
SELECT ENAME,JOB,SAL,DEPTNO,(SELECT DNAME FROM DEPT B WHERE B.DEPTNO = A.DEPTNO)FROM EMP A;

练习:查询员工工资比该员工岗位平均薪资高的员工信息。

SELECT *FROM EMP AWHERE A.SAL >(SELECT AVG(SAL) FROM EMP B WHERE A.JOB = B.JOB GROUP BY JOB);
```
子查询不能放在GROUP BY后面,其余都可以。
相关子查询有点难度啊 上课没听懂改天学明白了再更新

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/822638.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux学习:进程(5)进程控制

目录 1. 进程创建1.1 进程创建的方式与过程1.2 写时拷贝1.3 补充知识 2. 进程终止2.1 main函数返回值与进程退出码2.2 进程退出码的意义2.3 进程的执行结果与异常信号2.4 进程终止方式:exit与_exit 3. 进程等待3.1 进程创建与回收3.2 进程等待与回收的方式3.3 wait与…

51单片机、STM32连接串口助手常遇到的问题有哪些,具体应该如何解决

51单片机、STM32与电脑连接串口助手常见的问题及解决方法如下: 1.驱动问题:连接时电脑无法识别串口设备,通常是由于缺少驱动程序导致的。解决方法是安装正确的串口驱动程序,通常可以从芯片厂商的官方网站上下载到相应的驱动程序。…

鸿蒙语言TypeScript学习第18天:【泛型】

1、TypeScript 泛型 泛型(Generics)是一种编程语言特性,允许在定义函数、类、接口等时使用占位符来表示类型,而不是具体的类型。 泛型是一种在编写可重用、灵活且类型安全的代码时非常有用的功能。 使用泛型的主要目的是为了处…

树莓派安装tensorflow

树莓派安装tensorflow 使用编译好的版本自己选择版本进行编译armv71 架构 教程转载 使用编译好的版本 下载tensorflow编译好的版本 https://github.com/lhelontra/tensorflow-on-arm/tags由于python版本支持有限可能需要自己安装python 安装对应的python 自己选择版本进行编译…

【动态规划】【01背包 给定背包容量,装满背包最多有多少个物品】Leetcode 474. 一和零

【动态规划】【01背包 给定背包容量,装满背包最多有多少个物品】Leetcode 474. 一和零 解法 ---------------🎈🎈474. 一和零 题目链接🎈🎈------------------- 纯 0 - 1 背包 是求 给定背包容量 装满背包 的最大价值…

[蓝桥杯 2018 省 A] 航班时间

题目链接:航班时间 显然:去程时间飞行时间时差,回程时间飞行时间-时差 列方程组可知:飞行时间(去程时间回程时间)/2 本道题目还有一个难点在于如何读入和输出:可以采用scanf(&…

【随笔】Git 高级篇 -- 远程与本地不一致导致提交冲突 git push --rebase(三十一)

💌 所属专栏:【Git】 😀 作  者:我是夜阑的狗🐶 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询! 💖 欢迎大…

如何爬出 Kotlin 协程死锁的坑?

作者:悬衡 一、前言 在 Java 中有一个非常经典的死锁问题, 就是明明自己已经占用了线程池, 却还继续去申请它, 自己等自己, 就死锁了, 如下图和代码: // 这段代码将死锁到天荒地老final ExecutorService executorService Executors.newSingleThreadExecutor();exe…

【C 数据结构】单链表

文章目录 【 1. 基本原理 】1.1 链表的节点1.2 头指针、头节点、首元节点 【 2. 链表的创建 】2.0 创建1个空链表(仅有头节点)2.1 创建单链表(头插入法)*2.2 创建单链表(尾插入法) 【 3. 链表插入元素 】【…

爱之旅 | 爱的守望与宽恕

爱其实是一种持续的稳定情绪输出与反馈的表现。 情绪稳定的前提是丰富。 比如生活的丰富,有物质财富、社会关系、健康、知识和经验等。 一个人的生活如果多元化,拥有丰富的兴趣爱好、健康的社交关系、持续的个人成长,在面对生活中的挑战时自…

【SpringBoot实战篇】登录认证

🍀🌸明确需求--接口文档--思路分析--开发--测试🌸🍀💕 1 明确需求 2 接口文档 登录 3 思路分析 UserServic、UserMapper在注册的时候已经实现 现在我们重点看UserController 控制器 4 开发(实现&#xff0…

ChatGPT:让论文写作不再是难题

ChatGPT无限次数:点击直达 ChatGPT:让论文写作不再是难题 引言 在当今信息爆炸的时代,学术界对于高质量的论文需求日益增长。然而,对许多研究人员和学生来说,论文写作是一个艰巨且耗时的任务。幸运的是,随着人工智能…

C# 四种定时器的用法

C#四种定时器的用法 1. System.Windows.Forms.Timer 2. System.Threading.Timer 3. System.Timers.Timer 4. System.Windows.Threading.DispatcherTimer(WPF中的定时器) 1. System.Windows.Forms.Timer 使用方法如下: System.Windows.Forms.Timer timer new Syste…

做熟思维100历年真题700道,高效备考2024年思维100春季线上赛

今天是2024年4月17日,距离2024年春季思维100活动第一阶段的线上比赛4月20日还有3天。尽管主办方未提供2024年思维100活动的考试重点和大纲,但是我们仍然可以从历年的思维100真题中来分析和推测,把历年真题和背后的知识点吃透了,举…

Flink CDC:使用 Flink SQL 将多表写入一个 Kafka Topic 以及 Flink 作业数量的测试

博主历时三年精心创作的《大数据平台架构与原型实现:数据中台建设实战》一书现已由知名IT图书品牌电子工业出版社博文视点出版发行,点击《重磅推荐:建大数据平台太难了!给我发个工程原型吧!》了解图书详情,…

知识点补充

使用组合式函数来拆分setup逻辑 参考文章 基于组件拆分(vue2常用) a. 解决什么问题:复用 增加可维护性 b. 拆分的是什么:.vue HTML JS CSS c. 带来问题:一旦组件从一个变成了多个 必定形成嵌套关系 增加通信成本…

JQuery(四)---【使用JQuery实现动画效果】

目录 前言 一.隐藏和显示 1.1使用方法 1.2案例演示(1) 1.3隐藏/显示效果一键切换 二.淡入淡出效果 2.1使用方法 2.2案例演示(fadeIn) 2.3案例演示(fadeOut) 2.4案例演示(fadeToggle) 2.5案例演示(fadeTo) 三.滑动 3.1使用方法 3.2案例演示(slideDown) 3.3案例演示…

音频---数字mic

一、常见的数字mic pdm麦通过codec芯片将数字麦转换为i2s信号输入到SOC 纯pdm麦就是直接进入SOC的pdm接口,走的是PDM信号,PDM信号就是两个线,一根数据线一根时钟线(如顺芯ES7201/7202把MIC信号转换成PDM)。 二、DMIC…

pixhawk控制板的ArduPilot固件编译

0. 环境 - ubuntu18(依赖python2和pip,建议直接ubuntu18不用最新的) - pixhawk 2.4.8 - pixhawk 4 1. 获取源码 # 安装git sudo apt install git # 获取源码 cd ~/work git clone --recurse-submodules https://github.com/ArduPilot/a…

MDC使用手册精讲

MDC 背景: 线上排查问题时,请求在多个微服务之间进行调用,并发量较大的情况下,想跟踪某一个请求的链路,是需要花费一些时间才能梳理出来,而且还依赖于你的业务字段。而我们需要的是快速定位,快…