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