文章目录

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 salary
FROM employees
WHERE department_id = 3
LIMIT 1