从今天开始不熬夜

2022-09-18   阅读量: 516

Mysql

MySQL 子查询之 相关子查询

扫码加入数据分析学习群

1.相关子查询执行流程

如果子查询的执行依赖于外部查询,通常情况下,子查询的表用到了外部的表,并进行了条件关联.因此每执行一次外查询,子查询都要重新计算一次,这样的子查询称为关联子查询

关联子查询按照一行接一行的顺序查询,查询的每一行都执行一次子查询

2.代码示例

查询员工表中工资大于本部门平均工资的员工last_name,salary,department_id

方式一: 相关子查询

SELECT last_name,salary,department_id

FROM employees e1

WHERE salary > (

SELECT AVG(salary)

FROM employees e2

WHERE department_id = e1.department_id

);



方式二: 在FROM中声明子查询,即将子查询的结果看做一张新的表

SELECT *

FROM employees e,(

SELECT department_id,AVG(salary) avg_sal

FROM employees

GROUP BY department_id) t_dept_avg_sal

WHERE e.department_id = t_dept_avg_sal.department_id

AND e.salary > t_dept_avg_sal.avg_sal

使用from型的子查询时: 子查询需要使用()引起来,并且要给这个子查询取别名,把它当成一张'临时的虚拟表'来使用.





114.7108 1 0 关注作者 收藏

评论(0)


暂无数据

推荐课程