SQL 20) 统计各个部门的工资记录数

统计各个部门的工资记录数

http://www.nowcoder.com/questionTerminal/6a62b6c0a7324350a6d9959fa7c21db3

方法)三表连结再分组使用聚合函数

SELECT d.dept_no, d.dept_name, COUNT(s.emp_no)
FROM dept_emp AS de, departments AS d, salaries AS s
WHERE de.dept_no = d.dept_no
AND s.emp_no = de.emp_no
GROUP BY d.dept_no, d.dept_name
ORDER BY d.dept_no ASC;

21/3/25 更新
方法2)第二次做发现另一种方法,使用窗口函数count()over()

select distinct d.dept_no , d.dept_name, count(s.salary)over(partition by d.dept_no order by d.dept_no)
from departments as d join dept_emp as de on d.dept_no = de.dept_no 
                      join salaries as s  on s.emp_no = de.emp_no;
全部评论
请问一下,如果方法二第一个join改成left join,测试的还是需要加distinct,这是为什么呢?
点赞 回复 分享
发布于 2021-08-26 09:28
请问排序前进行分组的目的是什么呢?
点赞 回复 分享
发布于 2021-03-06 22:57

相关推荐

不愿透露姓名的神秘牛友
07-16 14:00
白火同学:其实你可以了解一下HR在Boss聊天的机制,想赢牌的前提是先会玩牌。 如果HR长时间没有理你,有可能是因为你的消息被其他应聘者的消息给挤到下面了,HR从上到下有可能只看个三四百个人就要到理想数量的简历了,而你恰好没有被看到,时间一长,你的消息在越来越下面。这种情况就需要你自己活跃一下,把消息提上去。 也可能是HR招的合适的人选了,但会一直挂着岗位,为了省重新开招聘岗位的钱,方便后面随时修改招聘要求。 当然也可能是HR吃饱了没事耍你玩,要了你的简历又不看,就看你自己怎么理解了。
点赞 评论 收藏
分享
07-18 18:45
已编辑
中山职业技术学院 Java
投递TP-LINK等公司7个岗位
点赞 评论 收藏
分享
06-23 10:26
佳木斯大学 Java
点赞 评论 收藏
分享
评论
16
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务