sql相关子查询的理解以及联合查询的部分理解

#题目:查询员工中工资大于本部门平均工资的员工的last_name,salary和其department_id
#方式1:使用相关子查询
想清楚这么个逻辑就能搞清楚,比如我们在进行where筛选的时候,是不是每个employees中的记录都要拿去筛选
而筛选的就是salary这个字段,所以每个记录筛选的时候呢,都会执行子查询,然后子查询了又会根据拿到的这个记录
去里面查,拿的是外面的这个记录的department_id字段去比较查出来的AVG,然后外层对比,如果可以则筛选成功,接着
外面筛选另一个记录
SELECT last_name,salary,department_id
FROM employees e1
WHERE salary > (
SELECT AVG(salary)
FROM employees e2
WHERE department_id = e1.department_id
);

#方式2:在FROM中声明子查询
通过上一段注释 去理解 相关和联合到底是什么意思,包括以前的知识,比如相关,就是首先关注的是
– where这个命令,将相关表或者联合表A,B中每一个记录都进行对比,比如A中的a1和B中的b1进行对比筛选,符合之后对其select
– 然后又将a2和b1对比,符合之后筛选如此,相当于双层遍历A和B,
SELECT e.last_name,e.salary,e.department_id
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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值