当前位置: 首页 > news >正文

【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);

子查询的类型

  1. 标量子查询:返回单个值(例如单个列、单行)。
  2. 多行子查询:返回多个行,但是每行只有一个列。
  3. 多列子查询:返回多个列的数据。
  4. 相关子查询:子查询的结果依赖于外层查询中的某些列。

二、标量子查询

标量子查询返回单个值,这个值可以作为条件与外层查询结合。常见的应用场景是用于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
);

解释:

  1. 子查询 (SELECT salary FROM employees WHERE department_id = 3 LIMIT 1) 返回部门ID为3的员工的薪水。
  2. 主查询从 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')
);

解释:

  1. 子查询 (SELECT department_id FROM departments WHERE department_name IN (‘Sales’, ‘Marketing’)) 返回属于 “Sales” 或 “Marketing” 部门的 department_id。
  2. 主查询通过 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
);

解释:

  1. 子查询 (SELECT AVG(salary) FROM employees GROUP BY department_id) 计算每个部门的平均薪资。
  2. 主查询返回薪资高于所有部门平均薪资的员工。

示例 2:多行子查询与ANY

假设我们要查询薪资高于某些部门最高薪资的员工,我们可以用 ANY 操作符。

SELECT first_name, last_name, salary
FROM employees
WHERE salary > ANY (SELECT MAX(salary)FROM employeesGROUP BY department_id
);

解释:

  1. 子查询 (SELECT MAX(salary) FROM employees GROUP BY department_id) 返回每个部门的最高薪水。
  2. 主查询返回薪水大于某些部门最高薪水的员工。

四、多列子查询

多列子查询返回多个列的结果。与单列子查询不同,主查询的条件需要与子查询的多个列进行匹配。

示例 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
);

解释:

  1. 内层子查询 (SELECT department_id FROM departments WHERE department_name = ‘Sales’) 获取 “Sales” 部门的 department_id。
  2. 中层子查询 (SELECT department_id, MAX(salary)…) 获取该部门的最高薪资和部门ID。
  3. 外层查询筛选出该部门薪资等于最高薪资的员工。

五、相关子查询

相关子查询与普通子查询不同,它依赖于外层查询中的字段。每次执行子查询时,外层查询中的一行都会传递给子查询。相关子查询通常用于需要逐行比较的情况。

示例 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
);

解释:

  1. 子查询 (SELECT MAX(salary) FROM employees e2 WHERE e1.department_id = e2.department_id AND e1.employee_id != e2.employee_id) 返回与外层查询同部门的所有其他员工的最高薪资。
  2. 外层查询返回薪资高于该部门其他员工薪资的员工。

示例 2:使用EXISTS与相关子查询

假设我们要查询有员工的部门信息,使用 EXISTS 来判断部门是否有员工。

SELECT department_name
FROM departments d
WHERE EXISTS (SELECT 1FROM employees eWHERE e.department_id = d.department_id
);

解释:

  1. 子查询 (SELECT 1 FROM employees e WHERE e.department_id = d.department_id) 检查是否存在某个部门有员工。
  2. 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的应用的习题

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

【Spring】AOP

AOP&#xff08;Aspect Oriented Programming&#xff0c;面向切面编程&#xff09;是一种编程范式&#xff0c;用来帮助开发者更好地组织程序结构。它的主要作用是为现有功能添加增强&#xff0c;而不需要修改原始代码。这与 Spring 框架提倡的“无侵入式编程”相符&#xff0…...

三维地图,智慧城市,商业智能BI,数据可视化大屏(Cesiumjs/UE)

绘图工具 三维地图&#xff1a;Cesiumjs 建模方式&#xff1a;激光点云建模、航拍倾斜摄影建模、GIS建模、BIM建模、手工建模 建模工具&#xff1a;C4D Blender GeoBuilding ArcGIS Cesiumjs <!DOCTYPE html> <html lang"en"> <head><meta …...

鸿蒙Next通过oss上传照片到阿里云

前言 最近在写纯血鸿蒙的APP&#xff0c;需要用到oss上传照片&#xff0c;之前的客户端 Android 和 IOS 都已经实现了&#xff0c;获取的阿里云签名的上传地址是服务端实现的&#xff0c;相信大部分公司都是这样的模式&#xff0c;服务端也是调用阿里云的SDK来实现的&#xff…...

小白爬虫——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时&#xff0c;变小&#xff0c;往左边找梯度接近0的值。 当梯度小于0时&#xff0c;减去一个负数会变大&#xff0c;往右边找梯度接近0的值&#xff0c;此时梯度从负数到0上升 2.Adam优化器实现原理 #coding:utf8import torch import torch.n…...

什么是多模态和模态

文章目录 前言一、定义1. 模态 (Modal)2. 非模态 (Non-modal) 二、GUI中1. 模态&#xff08;Modal&#xff09;对话框2. 非模态&#xff08;Modeless&#xff09;对话框 三、模态 vs 非模态 的对比四、何时使用模态和非模态对话框&#xff1f;五、Qt 中 exec() 与 show() 的区别…...

apache中的Worker 和 Prefork 之间的区别是什么?

文章目录 内存使用稳定性兼容性适用场景 Apache中的Worker和Prefork两种工作模式在内存使用、稳定性以及兼容性等方面存在区别 内存使用 Worker&#xff1a;由于使用线程&#xff0c;内存占用较少。Prefork&#xff1a;每个进程独立运行&#xff0c;内存消耗较大。 稳定性 W…...

系统监控——分布式链路追踪系统

摘要 本文深入探讨了分布式链路追踪系统的必要性与实施细节。随着软件架构的复杂化&#xff0c;传统的日志分析方法已不足以应对问题定位的需求。文章首先解释了链路追踪的基本概念&#xff0c;如Trace和Span&#xff0c;并讨论了其基本原理。接着&#xff0c;文章介绍了SkyWa…...

【Python]深入Python日志管理:从logging到分布式日志追踪的完整指南

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 日志是软件开发中的核心部分,尤其在分布式系统中,日志对于调试和问题定位至关重要。本篇文章将从Python标准库的logging模块出发,逐步探讨日志管理的最佳实践,涵盖日志配置、日志分层、日志格式化等基…...

DHCP Client的工作方式

【运作方式】 一开始Client没有IP资料 DHCPDISCOVER Client发出DHCPDISCOVER广播封包&#xff08;UDP port 67&#xff09;&#xff0c;寻找DHCP Server。 DHCPOFFER Client开始监听UDP port 68 &#xff08;任何&#xff09;DHCP Server收到DHCPDISCOVER封包后&#xff…...

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的思路是一样的&#xff0c;跟详细的细节可以参考博客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…...

【网络】每天掌握一个Linux命令 - iftop

在Linux系统中&#xff0c;iftop是网络管理的得力助手&#xff0c;能实时监控网络流量、连接情况等&#xff0c;帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...

零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?

一、核心优势&#xff1a;专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发&#xff0c;是一款收费低廉但功能全面的Windows NAS工具&#xff0c;主打“无学习成本部署” 。与其他NAS软件相比&#xff0c;其优势在于&#xff1a; 无需硬件改造&#xff1a;将任意W…...

Golang dig框架与GraphQL的完美结合

将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用&#xff0c;可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器&#xff0c;能够帮助开发者更好地管理复杂的依赖关系&#xff0c;而 GraphQL 则是一种用于 API 的查询语言&#xff0c;能够提…...

跨链模式:多链互操作架构与性能扩展方案

跨链模式&#xff1a;多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈&#xff1a;模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展&#xff08;H2Cross架构&#xff09;&#xff1a; 适配层&#xf…...

相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...

鱼香ros docker配置镜像报错:https://registry-1.docker.io/v2/

使用鱼香ros一件安装docker时的https://registry-1.docker.io/v2/问题 一键安装指令 wget http://fishros.com/install -O fishros && . fishros出现问题&#xff1a;docker pull 失败 网络不同&#xff0c;需要使用镜像源 按照如下步骤操作 sudo vi /etc/docker/dae…...

【论文阅读28】-CNN-BiLSTM-Attention-(2024)

本文把滑坡位移序列拆开、筛优质因子&#xff0c;再用 CNN-BiLSTM-Attention 来动态预测每个子序列&#xff0c;最后重构出总位移&#xff0c;预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵&#xff08;S…...

ArcGIS Pro制作水平横向图例+多级标注

今天介绍下载ArcGIS Pro中如何设置水平横向图例。 之前我们介绍了ArcGIS的横向图例制作&#xff1a;ArcGIS横向、多列图例、顺序重排、符号居中、批量更改图例符号等等&#xff08;ArcGIS出图图例8大技巧&#xff09;&#xff0c;那这次我们看看ArcGIS Pro如何更加快捷的操作。…...

AI病理诊断七剑下天山,医疗未来触手可及

一、病理诊断困局&#xff1a;刀尖上的医学艺术 1.1 金标准背后的隐痛 病理诊断被誉为"诊断的诊断"&#xff0c;医生需通过显微镜观察组织切片&#xff0c;在细胞迷宫中捕捉癌变信号。某省病理质控报告显示&#xff0c;基层医院误诊率达12%-15%&#xff0c;专家会诊…...

面向无人机海岸带生态系统监测的语义分割基准数据集

描述&#xff1a;海岸带生态系统的监测是维护生态平衡和可持续发展的重要任务。语义分割技术在遥感影像中的应用为海岸带生态系统的精准监测提供了有效手段。然而&#xff0c;目前该领域仍面临一个挑战&#xff0c;即缺乏公开的专门面向海岸带生态系统的语义分割基准数据集。受…...