在 SQL 中,子查询(也称为内联视图或嵌套查询)是一种在单个查询中执行另一个查询的方法。子查询通常用于过滤、计算或从另一个表中获取数据。子查询可以放在 SELECT、FROM、WHERE 和 HAVING 子句中。
以下是一些使用子查询的示例:
- 在 WHERE 子句中使用子查询:
SELECT * FROM employees WHERE salary > (SELECT AVG(salary) FROM employees);
这个查询将返回所有薪水高于员工平均薪水的员工。
- 在 SELECT 子句中使用子查询:
SELECT department, AVG(salary) as average_salary FROM employees GROUP BY department HAVING AVG(salary) > (SELECT AVG(salary) FROM employees);
这个查询将返回每个部门的平均薪水,但只显示那些平均薪水高于所有部门平均薪水的部门。
- 在 FROM 子句中使用子查询:
SELECT e1.* FROM employees e1 JOIN (SELECT department, AVG(salary) as average_salary FROM employees GROUP BY department) e2 ON e1.department = e2.department WHERE e1.salary > e2.average_salary;
这个查询将返回每个部门的员工薪水,但只显示那些薪水高于该部门平均薪水的员工。
- 在 JOIN 子句中使用子查询:
SELECT * FROM employees JOIN departments d ON e.department_id = d.department_id WHERE d.department_name IN (SELECT department_name FROM departments WHERE department_id != 1);
这个查询将返回所有部门的员工,但排除部门 ID 为 1 的部门。
这些示例展示了如何在 SQL 查询中使用子查询来过滤、计算和关联数据。子查询是一种强大的功能,可以帮助您编写更复杂的查询以满足特定需求。