【MySQL 09】复合查询 (带思维导图)

news2024/9/22 17:27:40

文章目录

  • 🌈 一、准备工作
  • 🌈 二、多表查询
    • ⭐ 1. 多表笛卡尔积
    • ⭐ 2. 多表查询示例
  • 🌈 三、自连接
  • 🌈 四、子查询
    • ⭐ 1. 标量子查询
    • ⭐ 2. 多行子查询 (需要插入其他博客的链接)
    • ⭐ 3. 多列子查询 (需要插入其他博客的链接)
    • ⭐ 4. 在 from 子句中使用子查询 (一切皆表)
  • 🌈 五、合并查询
    • ⭐ 1. union
    • ⭐ 2. union all

在这里插入图片描述

🌈 一、准备工作

  • 当前有三张表,分别是:部门表 dept,员工表 emp,薪资等级表 salgrade,之后的查询工作主要依赖于这三张表进行。
    • 这三张表各自包含的字段和每个字段的内容如下。
  1. 员工表 emp:员工编号 (empno)、员工姓名 (ename)、员工职位 (job)、员工领导的编号 (mgr)、雇佣时间 (hiredate)、月薪 (sal)、奖金 (comm)、部门编号 (deptno)。

image-20240817104531316

image-20240817104611038

  1. 部门表 dept:部门编号 (deptno)、部门名称 (dname)、部门所在地 (loc)。

image-20240817104818532

image-20240817104856942

  1. 薪资登记表 salgrade:等级 (grade)、此等级最低工资 (losal)、此等级最高工资 (hisal)。

image-20240817105133021

image-20240817105108090

🌈 二、多表查询

select * from1 ,2, ..., 表n;
  • 在实际开发中实际开发中数据通常来自不同的表,需要对多张表关联起来进行查询,这种查询被称为多表查询

  • 在进行多表查询时,只要将多张表的表名用逗号隔开依次放到 from 子句之后即可,MySQL 会对这多张表取笛卡尔积,用取到的笛卡尔积来作为多表查询的数据。

  • 多表查询的本质:多表查询就是对多张表取笛卡尔积,用笛卡尔积的形式将多张表合并成一张表,然后对这一张表进行单表查询

⭐ 1. 多表笛卡尔积

  • 多表笛卡尔积就是,一张表中的每一条记录都会和另一张表中的所有纪录进行组合。

    • 例:A = {a, b, c},B = {1, 2, 3},A 与 B 的笛卡尔积为:a1 a2 a3,b1 b2 b3,c1 c2 c3。
  • 在多表查询时,需要消除无效的笛卡尔积

select * from1,2 where1外键值 =2主键值;

举个例子

  • 对员工表 emp 和部门表 dept 表进行全列的多表查询,由于使用多表查询会产生笛卡尔积,对这两张表进行联合查询的结果如下。
    • 员工表 emp 和部门表 dept 合并形成了一张新的大表。
    • 员工表 emp 中的每一条记录都会和部门表 dept 中的所有记录进行组合从而产生很多无效的查询数据。

image-20240817112300675

对笛卡尔积进行过滤

  • 在进行多表查询时,将 emp 和 dept 这两张表合并成了一张表,可使用 where 条件过滤笛卡尔积对这一张表进行查询。

    • 例:由于两张表都有 deptno 这个字段,那么只需要筛选出与 emp 表中的 deptno 所对应的部门表的 deptno 即可。

    • 假设一个员工的所在部门是 10 号部门,那么他和其他的部门进行组合就没有任何意义,需要过滤掉这些无意义的笛卡尔积。

image-20240817113259575

⭐ 2. 多表查询示例

  • 为多表查询准备的案例如下:
  1. 显示雇员名、雇员工资以及所在部门的名字。
  2. 显示部门号为10的部门名,员工名和工资。
  3. 显示各个员工的姓名,工资,及工资级别。

1. 显示雇员名、雇员工资以及所在部门的名字

  • 部门名 dname 只存在于部门表 dept 中,而员工名 ename 和员工工资 sal 只存在于员工表 emp 中。需要同时对员工表 emp 和部门表 dept 进行多表查询,在 where 子句中指明筛选条件为 emp.deptno = dept.deptno。

image-20240817115439260

2. 显示部门号为10的部门名,员工名和工资

  • 在上一题的基础上,对 where 子句添加一个条件:并且部门号为 10 的记录。
    • 该筛选条件可以使用员工表 emp 中的部门编号,也可以使用部门表中的部门编号。

image-20240817115250427

3. 显示各个员工的姓名,工资,及工资级别

  • 员工名 ename 和员工工资 sal 只存在于员工表 emp 中,而工资级别 grade 只存在于工资等级表 salgrade 中。需要同时对员工表 emp 和工资等级表 salgrade 进行多表查询,在 where 子句中指定筛选条件为员工的工资在 losal 和 hisal 之间。

image-20240817120517405

🌈 三、自连接

select 字段列表 from 表A as 别名A, 表A as 别名B where 条件 ... ;
  • 既然对不同的表取笛卡尔积,同样也能对同一张表取笛卡尔积,对同一张表进行多表 (连接) 查询被称之为自连接
    • 在自连接中,必须对掉取别名
  • 如果一张表中的某个字段能够将表中的多条记录关联起来,则能通过自连接将表中与该字段关联的记录组合起来。

案例:显示员工 FORD 的上级领导的编号和姓名

  • 即使是员工的领导,甚至是公司老板,都会被记录在员工表 emp 中,因此 FORD 的上级领导的信息也需要在员工表 emp 中查询。
  1. 使用子查询解决:先对员工表进行查询得到 FORD 的领导的员工编号 mgr,再根据领导的员工编号从员工表中找到 FORD 领导的信息。

image-20240817171120129

  1. 使用自连接解决:emp 表中的领导编号 mgr 字段和员工编号字段 empno 可以关联起来。

image-20240817172010289

  • 因此可以将 emp 通过重命名的方式变成两张表,再对这两张表通过自连接的方式实现多表查询,将这两张表合并成一张未消除笛卡尔积的表。

    • 之后的操作就是消除这张表的笛卡尔积,在 where 子句中指定筛选条件为员工的领导编号 mgr 等于领导的员工编号 empno。

image-20240817172448089

🌈 四、子查询

select 字段列表 from t1 where column1 = (select column1 from t2);
  • MySQL 支持在一条查询语句的内部再执行一条查询语句,先执行最内部的查询语句,执行完后外部的 sql 语句根据内部 sql 的查询结果进行查询。

    • 嵌套在另一条查询语句中的查询语句被称之为子查询
  • 根据子查询返回的结果可将子查询分为标量子查询多行子查询多列子查询表子查询

    • 标量子查询:子查询返回的结果是单个的值,为单行单列的数据。
    • 多行子查询:子查询返回的结果为多行数据,每行都只能有一列。
    • 多列子查询:子查询返回的结果为多列数据,每列都只能有一行。
    • 表子查询:子查询返回的结果是一张子表,是多行多列的数据。
  • 在进行子查询时,如果搞不清楚逻辑,可以先将所有的子查询都拆成一条查询语句,再进行嵌套查询。

⭐ 1. 标量子查询

  • 子查询返回的结果是是单个的值,即表中背单行单列所框住的某一个格子的值。

image-20240817175850746

案例:显示与 SMITH 同一部门的员工

  • 在子查询中找出 SMITH 所在的部门号 deptno (SMITH 的部门号是单个的值)。

image-20240817181708607

  • 在 where 子句中指定筛选条件为员工部门号 deptno 等于子查询返回的部门号。

image-20240817180233667

⭐ 2. 多行子查询 (需要插入其他博客的链接)

  • 子查询返回的结果为多行数据,每行都只能有一列。
  • 多行子查询的常用操作符:=、<>、in、not in (这些操作符的意思详情见/表的增删查改 (此处要插入对应博客的链接)/中的操作符介绍)。

1. 查询和 10 号部门的工作岗位相同的员工的名字岗位,工资,部门号,但是不包含 10 号部门的员工

  • 先找出 10 号部门都有哪些工作岗位,由于某些员工的岗位可能相同,因此在查询时还需要进行去重操作。

image-20240817182651817

  • 再将上述查询作为多行子查询,在 where 子句中使用 in 关键字,判断员工的工作岗位是行子查询得到的这 3 个岗位中的一个。由于还要将 10 号部门的员工给筛出来,因此同时还需要在 where 子句中指定筛选条件为 deptno != 10。

image-20240817183325670

2. 显示工资比 30 号部门的所有员工的工资高的员工的姓名、工资和部门号

  • 先找出 30 号部门所有的工资,在查询时最好对结果进行去重。

image-20240817185228296

  • 再将上述查询语句作为多行子查询,在 where 子句中使用 all 关键字,判断员工的工资是否 > 行子查询得到的所有工资。

image-20240817185559750

  • 这道题也能看作找出员工表中比 30 号部门中的最高薪资高的员工的相关信息,可以使用标量子查询找出 30 号部门的最高薪资。

image-20240817190718425

3. 显示工资比 30 号部门的任意员工的工资高的员工的姓名、工资和部门号,包含 30 号部门的员工

  • 先找出 30 号部门所有的工资,在查询时最好对结果进行去重。
  • 再将上述查询语句最为多行子查询,在 where 子句中使用 any 关键字,只要工资高于行子查询得出的结果中的任意一个即可。

image-20240817191501973

  • 换个角度看,大于任意一个表示工资至少要大于 30 号部门的最低薪资才行,可以使用标量子查询找出 30 号部门的最低薪资。

image-20240817191828071

⭐ 3. 多列子查询 (需要插入其他博客的链接)

  • 子查询返回的结果为多列数据,每列都只能有一行。

  • 多列子查询的常用操作符:in、not in、any、some、all ( (这些操作符的意思详情见/表的增删查改 (此处要插入对应博客的链接)/中的操作符介绍)。

案例:显示和 SMITH 的部门和岗位完全相同的员工,但不包含 SMITH 本人

  • 先查询 SMITH 所在部门的部门编号 deptno 以及他的岗位 job。

image-20240817193542147

  • 将上述查询作为多列子查询,在 where 子句中,指定筛选条件为部门编号 deptno 和岗位 job 都等于多列子查询得到的部门号和岗位,并且员工的姓名 ename != SMITH。

image-20240817194013405

⭐ 4. 在 from 子句中使用子查询 (一切皆表)

  • 子查询不仅仅能在 where 中充当判断条件,也能在 from 子句中充当笛卡尔积
  • 支持这种做法的原因是,在 MySQL 中,一切皆表,因此也能将子查询查出来的结果当成一张临时表来看待。
  • 注意:在 from 子句中使用子查询时,必须为子查询得到的临时表取别名

1. 显示每个高于自己部门平均工资的员工的姓名、部门、工资和部门的平均工资

  • 先使用 group by 分组查询找出每个部门的平均工资,显示出来的信息就是所说的临时表。

image-20240817195336970

  • 将上述查询的结果作为临时表放在 from 子句中,再对员工表和临时表取笛卡尔积。在 where 子句中指定筛选条件为员工的部门号等于临时表中的部门号,并且员工的工资大于临时表中的平均工资。

image-20240817200121132

2. 显示每个部门工资最高的员工的姓名、工资、部门和部门的最高工资

  • 先使用 max 函数和 group by 分组查询找出每个部门的最高工资。

image-20240817201612442

  • 将上述查询结果作为临时表放在 from 子句中与 emp 作笛卡尔积,在 where 子句中指定筛选条件为员工的部门号等于临时表的部门号,并且员工的工资等于临时表的最高工资。

image-20240817201938732

3. 显示每个部门的信息(部门名,编号,地址)和人员数量

  1. 使用多表查询:对员工表 emp 和部门表取 dept 取笛卡尔积,在 where 子句中指定筛选条件为 emp.deptno = dept.deptno 筛出部门号相同的记录,在 group by 子句中指定按照部门号 deptno、部门名 dname 和部门地址 loc j进行分组,统计出每个部门的人数。

image-20240817204208167

  1. 使用子查询(推荐):
  • 在员工表 emp 中使用 group by 分组查询,找出每个部门的人员数量、部门编号。

image-20240817203226341

  • 将上述查询结果作为临时表放进 from 子句中,对部门表和临时表作笛卡尔积,将 where 子句的筛选条件指定为部门表的部门编号等于临时表的部门编号。

image-20240817205017354

  • 由于一切皆表的缘故,该方法其实也算是一种多表查询,只不过是用子查询的形式展现出来了而已。

🌈 五、合并查询

select 字段列表 from 表A ... union [all] select 字段列表 from 表B ... ;
  • MySQL 支持将多次查询的结果合并起来,形成一个新的查询结果集,可使用的操作符有 union 和 union all。
  • union 和 union all 都能获得多个查询结果的并集,区别是 union 会对合并后的并集进行去重,而 union all 则不会。
  • 注意:对于合并查询的多张表的列数必须保持一致,字段类型也需要保持一致。

⭐ 1. union

  • 该操作符用于取得两个结果集的并集。当使用该操作符时,会去掉结果集中的重复行。

案例:将工资大于 2500 或职位是 MANAGER 的人找出来

  • 找出工资 sal 大于 2500 的人。

image-20240817211350717

  • 找出职位 job 是 MANAGER 的人。

image-20240817211626713

  • 使用 union 关键字将上述两种查询结果进行去重合并(合并的前提是两个查询的字段数和字段类型要一致)。

image-20240817211727864

⭐ 2. union all

  • 该操作符用于取得两个结果集的并集。当使用该操作符时,不会去掉结果集中的重复行。

案例:将工资大于 25000 或职位是 MANAGER 的人找出来

  • 前置操作就不演示了,直接使用 union 关键字将上述两种查询结果进行不去重合并

image-20240817211858910

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

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

相关文章

小米SU7销量超特斯拉,新车明年上半年发布

小米 SU7&#xff0c;一款国内新能源车品牌纯血新势力旗下首款轿车&#xff0c;上市短短 4 个月卖出超 4 万台&#xff0c;月均销量过万。 该说不说&#xff0c;这放在整个新能源汽车工业史上也足以称得上是一件小刀喇拍屁股&#xff0c;让人开了眼的事儿。 就在本月初&#x…

大模型在企业数智化转型中可以做哪些事情?

在数字化浪潮的推动下&#xff0c;企业数智化转型已成为不可逆转的趋势。作为人工智能技术的集大成者&#xff0c;大模型以其强大的数据处理能力、深度学习能力及广泛的应用场景&#xff0c;正逐步成为企业数智化转型的核心驱动力。 大模型&#xff1a;智能时代的基石 大模型…

Error: ReferenceError: ReadableStream is not defined

midway项目在build完&#xff0c;docker启动时&#xff0c;莫名地报错Error: ReferenceError: ReadableStream is not defined&#xff0c;之前一直好好地&#xff0c;初时以为是新加的代码引起&#xff0c;后来排除了。 报错如下&#xff1a; 2024-08-20 11:57:51.446 ERROR …

【教学类-76-01】20240820书包01(图案最大化)

背景需求 通义万相生成图片&#xff0c;把图案最大化的方法&#xff08;切掉白边&#xff09; 【教学类-75-01】20240817“通义万相图片最大化透明png”的修图流程-CSDN博客文章浏览阅读1.6k次&#xff0c;点赞56次&#xff0c;收藏17次。【教学类-75-01】20240817“通义万相…

Aseembly(八)-汇编语言编写程序

前言 在该系列的第六篇文章我们主要讲述了:关于栈的寄存器:SS和SP的问题 来回一下: 对于栈指针来说,栈在被开辟的时候,首先要通过SS指针去找到开辟栈的地址空间的首地址,随后,SP指针指向该栈空间的末尾的下一个空间处.当执行push指令时,sp会-2 随后将目标压入栈中 当执行pop指…

volta引发的血案

什么是volta volta用于做项目级别的node版本控制&#xff0c;当手头上的项目有多个时&#xff0c;且node版本可能还不一样&#xff0c;我们需要不断切换node版本。使用volta可以很好的解决这个问题。只需要安装volta&#xff0c;然后在下面的package.json中配置好node版本即可…

鸿蒙HarmonOS实战开发: CMake脚本编写构建NDK工程

NDK工程构建 HarmonyOS NDK默认使用CMake作为构建系统&#xff0c;随包提供了符合HarmonyOS工具链的基础配置文件ohos.toolchain.cmake&#xff0c;用于预定义CMake变量来简化开发者配置。 常用的NDK工程构建方式有&#xff1a; 从源码构建 源码构建也有不同方式&#xff1a;…

机器学习在智能复合材料中的应用与实践

在人工智能与复合材料技术融合的背景下&#xff0c;复合材料的研究和应用正迅速发展&#xff0c;创新解决方 案层出不穷。从复合材料性能的精确预测到复杂材料结构的智能设计&#xff0c;从数据驱动的材料结构优 化到多尺度分析&#xff0c;人工智能技术正以其强大的数据处理能…

深度学习设计模式之策略模式

文章目录 前言一、介绍二、特点三、详细介绍1.核心组成2.代码示例3.优缺点优点缺点 4.使用场景 总结 前言 策略模式定义一系列算法&#xff0c;封装每个算法&#xff0c;并使它们可以互换。 一、介绍 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为型设计模式&…

Linux:网络基础概念

网络发展 独立模式: 计算机之间相互独立; 网络互联: 多台计算机连接在一起, 完成数据共享; 局域网 LAN: 计算机数量更多了, 通过交换机和路由器连接在一起; 广域网 WAN: 将远隔千里的计算机都连在一起; 所谓 "局域网" 和 "广域网" 只是一个相对的概念. 比如…

【C++ 第十四章】红黑树

前言&#xff1a; 学习本章&#xff0c;需要先学习 AVL树的 旋转&#xff0c;因为 红黑树也需要旋转调整来平衡&#xff0c;下面讲解将不赘述 旋转的原理和操作 红黑树的旋转 和 AVL树的旋转 唯一不同的是&#xff1a;旋转的判断使用逻辑 AVL树的旋转 可以通过 平衡因子 判断…

关于c++ grpc 和 c# grpc 通信的问题 以及 grpc 认证问题

一、c 和 c# 通信 c# 端服务器 如果域名 输入的是 https &#xff0c;则 c 端需要匹配使用&#xff0c;也就是c 端需要进行安全认证。如果是http 则c 端不需要认证&#xff08;基于c#的grpc 未 通信成功&#xff09; 参考如下网址可以写一个简单的 .net grpc服务器 &#xff08…

基于java的综合小区管理系统论文.doc

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统综合小区管理系统信息管理难度大&#xff0c;容错率低&am…

diamond安装与使用

1.前言 diamond是一款用于蛋白质和翻译后DNA搜索的序列比对工具&#xff0c;专为大规模序列数据的高性能分析设计。其主要特点包括&#xff1a; - 与BLAST相比&#xff0c;蛋白质和翻译后DNA的成对比对速度快100倍至10000倍。 2. 参考 https://github.com/bbuchfink/diamond …

微知-lspci如何查看pcie设备树状结构(-t)

对于查看pcie设备列表除了看是否存在 还需要看拓扑结构。如何看&#xff1f; lspci -t以减号为分割说明 第一列数字是域段 和 bus id。比如0000:00中0000是域 00是busid 第二列 01.2中01是device id。2是functionid 如果还有下游设备device还有一个指定busid的序号

[数据集][目标检测]夜间老鼠检测数据集VOC+YOLO格式316张1类别+视频文件1个

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;316 标注数量(xml文件个数)&#xff1a;316 标注数量(txt文件个数)&#xff1a;316 标注类别…

I.MX6U交叉编译Qt项目-思维导图-学习笔记-基于正点原子阿尔法开发板

I.MX6U交叉编译Qt项目 安装交叉编译器 交叉编译器介绍 拷贝fsl-imx-x11-glibc-x86_64-meta-toolchain-qt5-cortexa7hf-neon-toolchain-4.1.15-2.1.0.sh至ubuntu 执行下面的指令修改脚本的权限&#xff0c;修改权限后可以看到此脚本颜色显示改变&#xff0c;说明修改成功 chmod…

理解Flink算子链

前言 对于flink初学者,如果我们观察WebUi中任务执行情况,可能会有一个疑惑,为什么节点和代码中的算子对不上? 从WebUi上看起来像是一个节点,会把转换处理的很多个任务都连接在一起,合并成了一个“大任务”。这又是怎么回事呢? 算子间的数据传输 我们先来考察一下算子…

Vue 旋转动画效果

目录 前言效果演示具体代码实现 前言 这里记录一个旋转动画&#xff0c;在鼠标经过的时候停止&#xff0c;鼠标离开继续旋转。 实现思路&#xff1a; 利用keyframes关键字定义一个旋转动画 效果演示 具体代码实现 <template><div class"container"><…

Cuda 基于Cmake创建Cuda项目

文章目录 一、简介1.1GPU的优势1.2 CUDA:通用并行计算平台和编程模型 二、Cuda项目三、实现效果参考资料 一、简介 1.1GPU的优势 图形处理单元(GPU)1在相同的价格和功率范围内提供比CPU高得多的指令吞吐量和内存带宽。许多应用程序利用这些更高的功能在GPU上比在CPU上运行得更…