【08】MySQL复杂查询:子查询语句详解与示例
文章目录
- 一、子查询的基本概念
- 子查询的基本结构
- 子查询的类型
- 二、标量子查询
- 示例 1:标量子查询
- 示例 2:标量子查询与IN组合
- 三、多行子查询
- 示例 1:多行子查询与IN
- 示例 2:多行子查询与ANY
- 四、多列子查询
- 示例 1:多列子查询
- 五、相关子查询
- 示例 1:相关子查询
- 示例 2:使用EXISTS与相关子查询
- 六、子查询的优化
- 七、总结

MySQL子查询(Subquery)是指在一个查询语句中嵌套另一个查询语句。子查询常用于实现复杂的查询逻辑,帮助我们在主查询中引用计算出的结果。子查询通常分为标量子查询、多行子查询、多列子查询以及相关子查询,它们在查询中发挥着不同的作用。本文将详细解析MySQL中子查询的基本语法、分类以及常见的使用场景,并结合具体示例进行说明。
一、子查询的基本概念
子查询通常被用作SELECT、FROM、WHERE、HAVING等子句的一部分,目的是通过另一个查询语句的结果来帮助主查询完成复杂的数据提取。子查询可以在查询中作为输入,提供一个临时的结果集。MySQL允许子查询返回单个值、多个值或者甚至一个完整的表。
子查询的基本结构
SELECT column1, column2, ...
FROM table_name
WHERE column_name OPERATOR (SELECT column_name FROM table_name WHERE condition);
子查询的类型
- 标量子查询:返回单个值(例如单个列、单行)。
- 多行子查询:返回多个行,但是每行只有一个列。
- 多列子查询:返回多个列的数据。
- 相关子查询:子查询的结果依赖于外层查询中的某些列。
二、标量子查询
标量子查询返回单个值,这个值可以作为条件与外层查询结合。常见的应用场景是用于WHERE子句中与一个常量进行比较。
示例 1:标量子查询
假设我们有一个员工表 employees,其中包含字段 salary 和 department_id,我们要查询比部门ID为3的员工薪水更高的所有员工。
SELECT first_name, last_name, salary
FROM employees
WHERE salary > (SELECT salaryFROM employeesWHERE department_id = 3LIMIT 1
);
解释:
- 子查询 (SELECT salary FROM employees WHERE department_id = 3 LIMIT 1) 返回部门ID为3的员工的薪水。
- 主查询从 employees 表中返回所有薪水高于该薪水的员工信息。
示例 2:标量子查询与IN组合
假设我们有两个表:employees 和 departments,我们要查询属于 “Sales” 或 “Marketing” 部门的员工信息。
SELECT first_name, last_name
FROM employees
WHERE department_id IN (SELECT department_idFROM departmentsWHERE department_name IN ('Sales', 'Marketing')
);
解释:
- 子查询 (SELECT department_id FROM departments WHERE department_name IN (‘Sales’, ‘Marketing’)) 返回属于 “Sales” 或 “Marketing” 部门的 department_id。
- 主查询通过 IN 子句来过滤出这些部门下的员工。
三、多行子查询
多行子查询返回多个值,通常与IN、ANY、ALL等操作符一起使用。它可以返回一个列的多个值供外层查询使用。
示例 1:多行子查询与IN
假设我们有一个 employees 表,其中有 salary 和 department_id 字段。我们要查询薪资高于所有部门平均薪资的员工。
SELECT first_name, last_name, salary
FROM employees
WHERE salary > ALL (SELECT AVG(salary)FROM employeesGROUP BY department_id
);
解释:
- 子查询 (SELECT AVG(salary) FROM employees GROUP BY department_id) 计算每个部门的平均薪资。
- 主查询返回薪资高于所有部门平均薪资的员工。
示例 2:多行子查询与ANY
假设我们要查询薪资高于某些部门最高薪资的员工,我们可以用 ANY 操作符。
SELECT first_name, last_name, salary
FROM employees
WHERE salary > ANY (SELECT MAX(salary)FROM employeesGROUP BY department_id
);
解释:
- 子查询 (SELECT MAX(salary) FROM employees GROUP BY department_id) 返回每个部门的最高薪水。
- 主查询返回薪水大于某些部门最高薪水的员工。
四、多列子查询
多列子查询返回多个列的结果。与单列子查询不同,主查询的条件需要与子查询的多个列进行匹配。
示例 1:多列子查询
假设我们有两个表:employees 和 departments,我们要查询在"Sales"部门的员工信息,并且薪资高于部门最高薪资。
SELECT first_name, last_name, salary
FROM employees
WHERE (department_id, salary) = (SELECT department_id, MAX(salary)FROM employeesWHERE department_id = (SELECT department_id FROM departments WHERE department_name = 'Sales')GROUP BY department_id
);
解释:
- 内层子查询 (SELECT department_id FROM departments WHERE department_name = ‘Sales’) 获取 “Sales” 部门的 department_id。
- 中层子查询 (SELECT department_id, MAX(salary)…) 获取该部门的最高薪资和部门ID。
- 外层查询筛选出该部门薪资等于最高薪资的员工。
五、相关子查询
相关子查询与普通子查询不同,它依赖于外层查询中的字段。每次执行子查询时,外层查询中的一行都会传递给子查询。相关子查询通常用于需要逐行比较的情况。
示例 1:相关子查询
假设我们有一个 employees 表和一个 departments 表,我们要查询薪水高于同部门所有其他员工薪水的员工。
SELECT first_name, last_name, salary
FROM employees e1
WHERE salary > (SELECT MAX(salary)FROM employees e2WHERE e1.department_id = e2.department_idAND e1.employee_id != e2.employee_id
);
解释:
- 子查询 (SELECT MAX(salary) FROM employees e2 WHERE e1.department_id = e2.department_id AND e1.employee_id != e2.employee_id) 返回与外层查询同部门的所有其他员工的最高薪资。
- 外层查询返回薪资高于该部门其他员工薪资的员工。
示例 2:使用EXISTS与相关子查询
假设我们要查询有员工的部门信息,使用 EXISTS 来判断部门是否有员工。
SELECT department_name
FROM departments d
WHERE EXISTS (SELECT 1FROM employees eWHERE e.department_id = d.department_id
);
解释:
- 子查询 (SELECT 1 FROM employees e WHERE e.department_id = d.department_id) 检查是否存在某个部门有员工。
- EXISTS 关键字用于判断子查询是否返回结果,只有在子查询有结果时,外层查询才会返回该部门的名称。
六、子查询的优化
子查询在某些情况下可能会导致性能问题,尤其是当子查询的结果集非常大时。以下是一些优化建议:
- 避免多次计算相同的子查询:如果子查询结果在多个地方使用,可以将其结果存储到临时表中,避免重复执行。
- 使用连接代替子查询:在很多情况下,可以使用 JOIN 来替代子查询。JOIN 通常比子查询效率更高,因为它通过索引来加速查询。
- 避免在WHERE子句中使用子查询:在可能的情况下,考虑使用JOIN 或 EXISTS,这些方式通常比在 WHERE 子句中嵌套子查询更高效。
七、总结
MySQL的子查询功能强大,能够在许多复杂查询中帮助我们提取数据。通过标量子查询、多行子查询、多列子查询和相关子查询,开发者可以灵活地在查询中使用嵌套查询,处理各种复杂的数据需求。了解并掌握子查询的语法和优化技巧,将帮助你在数据库设计和查询过程中更加高效地操作数据。
相关文章:

【08】MySQL复杂查询:子查询语句详解与示例
文章目录 一、子查询的基本概念子查询的基本结构子查询的类型 二、标量子查询示例 1:标量子查询示例 2:标量子查询与IN组合 三、多行子查询示例 1:多行子查询与IN示例 2:多行子查询与ANY 四、多列子查询示例 1:多列子查…...
Unity 相机旋转及角度限制
前言 由于欧拉角具有直观的可读性,做相机旋转时选择修改eulerAngles 来实现旋转,但实际效果与预期稍有不同,这是因为欧拉角受到万向锁(Gimbal Lock)的影响,在赋值时需要对输入的角度进行调整。 if (value…...

error=‘null‘], commandType=io.lettuce.core.RedisPublisher$SubscriptionCommand]
问题 查看java应用启动日志输出下面错误: errornull], commandTypeio.lettuce.core.RedisPublisher$SubscriptionCommand] Completing command LatencyMeteredCommand [typeINFO, outputStatusOutput [output# Server redis_version:4.0.14 redis_git_sha1:000…...
Golang 字符串字面量表示方法
文章目录 1.普通字符串字面量(Double-Quoted String Literals)2.原始字符串字面量(Raw String Literals)3.字节字符串字面量(Byte Slice Literals)4.码值表示字符串字面量Unicode 转义序列UTF8 转义序列十六…...

03_Webpack模块打包工具
03_Webpack模块打包工具 目录 知识点自测 以下哪个选项是 ECMAScript 默认导出和导入的语法? A:export 和 require B:module.exports {} 和 import 变量名 C:export default 和 import 变量名 D:export 和 import {…...

【目标跟踪】AntiUAV600数据集详细介绍
AntiUAV600数据集的提出是为了适应真实场景,即无人机可能会随时随地出现和消失。目前提出的Anti-UAV任务都只是将其看做与跟踪其他目标一样的任务,没有结合现实情况考虑。 论文链接:https://arxiv.org/pdf/2306.15767https://arxiv.org/pdf/…...

十、JavaScript的应用的习题
题目一 在网页中显示一个工作中的 “ 数字时钟 ”,如图所示 运行效果 代码 <!DOCTYPE html> <html><head><meta charset"utf-8"><title>动态时钟</title><style>.all{width: 660px;height: 350px;margin: 60p…...

【Spring】AOP
AOP(Aspect Oriented Programming,面向切面编程)是一种编程范式,用来帮助开发者更好地组织程序结构。它的主要作用是为现有功能添加增强,而不需要修改原始代码。这与 Spring 框架提倡的“无侵入式编程”相符࿰…...
三维地图,智慧城市,商业智能BI,数据可视化大屏(Cesiumjs/UE)
绘图工具 三维地图:Cesiumjs 建模方式:激光点云建模、航拍倾斜摄影建模、GIS建模、BIM建模、手工建模 建模工具:C4D Blender GeoBuilding ArcGIS Cesiumjs <!DOCTYPE html> <html lang"en"> <head><meta …...
鸿蒙Next通过oss上传照片到阿里云
前言 最近在写纯血鸿蒙的APP,需要用到oss上传照片,之前的客户端 Android 和 IOS 都已经实现了,获取的阿里云签名的上传地址是服务端实现的,相信大部分公司都是这样的模式,服务端也是调用阿里云的SDK来实现的ÿ…...

小白爬虫——selenium入门超详细教程
目录 一、selenium简介 二、环境安装 2.1、安装Selenium 2.2、浏览器驱动安装 三、基本操作 3.1、对页面进行操作 3.1.1、初始化webdriver 3.1.2、打开网页 3.1.3、页面操作 3.1.4、页面数据提取 3.1.5、关闭页面 3.1.6、综合小案例 3.2、对页面元素进行操作 3.2.…...

nlp培训重点
1. SGD梯度下降公式 当梯度大于0时,变小,往左边找梯度接近0的值。 当梯度小于0时,减去一个负数会变大,往右边找梯度接近0的值,此时梯度从负数到0上升 2.Adam优化器实现原理 #coding:utf8import torch import torch.n…...
什么是多模态和模态
文章目录 前言一、定义1. 模态 (Modal)2. 非模态 (Non-modal) 二、GUI中1. 模态(Modal)对话框2. 非模态(Modeless)对话框 三、模态 vs 非模态 的对比四、何时使用模态和非模态对话框?五、Qt 中 exec() 与 show() 的区别…...
apache中的Worker 和 Prefork 之间的区别是什么?
文章目录 内存使用稳定性兼容性适用场景 Apache中的Worker和Prefork两种工作模式在内存使用、稳定性以及兼容性等方面存在区别 内存使用 Worker:由于使用线程,内存占用较少。Prefork:每个进程独立运行,内存消耗较大。 稳定性 W…...

系统监控——分布式链路追踪系统
摘要 本文深入探讨了分布式链路追踪系统的必要性与实施细节。随着软件架构的复杂化,传统的日志分析方法已不足以应对问题定位的需求。文章首先解释了链路追踪的基本概念,如Trace和Span,并讨论了其基本原理。接着,文章介绍了SkyWa…...
【Python]深入Python日志管理:从logging到分布式日志追踪的完整指南
《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 日志是软件开发中的核心部分,尤其在分布式系统中,日志对于调试和问题定位至关重要。本篇文章将从Python标准库的logging模块出发,逐步探讨日志管理的最佳实践,涵盖日志配置、日志分层、日志格式化等基…...
DHCP Client的工作方式
【运作方式】 一开始Client没有IP资料 DHCPDISCOVER Client发出DHCPDISCOVER广播封包(UDP port 67),寻找DHCP Server。 DHCPOFFER Client开始监听UDP port 68 (任何)DHCP Server收到DHCPDISCOVER封包后ÿ…...
docker-常用应用部署dockerfile模板
文章目录 概述Springboot-Djava.security.egdfile:/dev/./urandom参数说明 vue应用部署nginx.conf配置Dockerfile 概述 本文列举了Java开发中常用如SpringBoot、Vue前端等类型的应用Docker部署所需的DockerFile Springboot FROM anapsix/alpine-java:8_server-jre_unlimited…...

Unity3D学习FPS游戏(13)玩家血量控制
玩家血量控制 血条UI玩家Canvas下的Slider血量逻辑控制 子弹攻击掉血子弹发射者的区分玩家受伤逻辑子弹碰撞检测 效果 血条UI 和之前我们前面介绍的玩家武器弹夹UI的思路是一样的,跟详细的细节可以参考博客Unity3D装弹和弹夹UI显示。 玩家Canvas下的Slider 之前玩…...

TDesign:Switch开关
Switch 开关 文档地址 view TDSwitch(isOn: controller.isDefault, // 默认是否开启状态trackOnColor: AppColors.mainColor,onChanged: ((bool value){controller.onTapSwitch(value);return value;}), ),controller bool isDefault true; // 是否默认 void onTapSwitch(bool…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...

stm32G473的flash模式是单bank还是双bank?
今天突然有人stm32G473的flash模式是单bank还是双bank?由于时间太久,我真忘记了。搜搜发现,还真有人和我一样。见下面的链接:https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...
React Native 导航系统实战(React Navigation)
导航系统实战(React Navigation) React Navigation 是 React Native 应用中最常用的导航库之一,它提供了多种导航模式,如堆栈导航(Stack Navigator)、标签导航(Tab Navigator)和抽屉…...

1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...
ffmpeg(四):滤镜命令
FFmpeg 的滤镜命令是用于音视频处理中的强大工具,可以完成剪裁、缩放、加水印、调色、合成、旋转、模糊、叠加字幕等复杂的操作。其核心语法格式一般如下: ffmpeg -i input.mp4 -vf "滤镜参数" output.mp4或者带音频滤镜: ffmpeg…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...

(转)什么是DockerCompose?它有什么作用?
一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器。 Compose文件是一个文本文件,通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...

GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...
Web 架构之 CDN 加速原理与落地实践
文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 …...
iOS性能调优实战:借助克魔(KeyMob)与常用工具深度洞察App瓶颈
在日常iOS开发过程中,性能问题往往是最令人头疼的一类Bug。尤其是在App上线前的压测阶段或是处理用户反馈的高发期,开发者往往需要面对卡顿、崩溃、能耗异常、日志混乱等一系列问题。这些问题表面上看似偶发,但背后往往隐藏着系统资源调度不当…...