【MySQL】(基础篇十二) —— 子查询

分组数据

本文介绍什么是子查询以及如何使用它们。

SQL允许我们创建子查询(subquery),即嵌套在其他查询中的查询。这样可以实现更复杂的查询,理解这个概念的最好方法是考察几个例子。

利用子查询进行过滤

需求:查询employees表中department_id为IT的所有员工信息

要实现这个查询,首先要在departments表中查找到it对应的department_id,然后再根据department_id在employees表中查询对应的员工信息。要在一个语句中完成两次查询,使用子查询可以很好地完成任务。

SELECT  * 
FROM `employees`
WHERE department_id IN (
      SELECT department_id
      FROM `departments`
      WHERE department_name = 'it'
);

在SELECT语句中,子查询总是从内向外处理。在处理上面的SELECT语句时,MySQL实际上执行了两个操作。先执行内部的子查询,然后将结果返回给外面的查询

在WHERE子句中使用子查询(如这里所示),应该保证SELECT语句具有与WHERE子句中相同数目的列。通常,子查询将返回单个列并且与单个列匹配,但如果需要也可以使用多个列。

作为计算字段使用子查询

需求:查询departments表中,每个部门拥有的员工数量

员工数量在employees表中使用聚集函数查询,然后作为子查询传递回给departments表中

SELECT department_id, department_name, 
     (SELECT COUNT(*)
     FROM employees
     WHERE employees.department_id = departments.department_id) as total_people 
FROM departments

运行结果:
在这里插入图片描述

相关推荐

  1. MySQL数据库(基础

    2024-06-16 09:38:03       15 阅读
  2. 11. Mysql 查询

    2024-06-16 09:38:03       39 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-16 09:38:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-16 09:38:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-16 09:38:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-16 09:38:03       18 阅读

热门阅读

  1. Highcharts 动态图

    2024-06-16 09:38:03       7 阅读
  2. OSINT技术情报精选·2024年6月第2周

    2024-06-16 09:38:03       8 阅读
  3. linux执行mysql命令备份回复数据库

    2024-06-16 09:38:03       8 阅读
  4. 使用winehq在Mac上成功运行Win系统exe应用程序

    2024-06-16 09:38:03       8 阅读
  5. PHP序列化基础概念:深入理解数据存储与传输

    2024-06-16 09:38:03       8 阅读
  6. 【分形技术在神经网络建模中的应用】

    2024-06-16 09:38:03       9 阅读