题解 | #汇总各个部门当前员工的title类型的分配数目#

汇总各个部门当前员工的title类型的分配数目

http://www.nowcoder.com/practice/4bcb6a7d3e39423291d2f7bdbbff87f8

select de.dept_no,dept_name,title,count(*) `count`
from departments de,dept_emp e,titles t
where de.dept_no = e.dept_no and (t.emp_no = e.emp_no)
GROUP BY de.dept_no , t.title
ORDER BY de.dept_no , t.title

这个题目思路出来了就不难了。

思路:首先我们先把部门和员工一一对应(de.dept_no = e.dept_no),然后员工和titles对应(t.emp_no = e.emp_no),这样就实现了三表关联了,而且一一对应。

问题描述中有一个要求是(汇总各个部门当前员工的title类型的分配数目),可以发现进行分组的话,显然只对部门分组时不行的,因为一个部门可以有多种title类型,到了这里应该意识到还要进一步对title类型分组(GROUP BY de.dept_no , t.title),这样就实现了每个部门的每种title类型的个数(count(*)),最后按照要求排序就可以了。

全部评论

相关推荐

03-29 17:05
门头沟学院 Java
asdasdasda...:我前段时间找工作焦虑,有几天连续熬夜熬穿了,然后心脏突然不舒服,立马躺床上睡觉了,然后第二天还是不舒服,去看医生说是心率不齐,吓得我后面天天早早睡觉,调养身体,过了好几天才好过来。所以真的,工作这些东西哪有那么重要,最多钱多一点钱少一点,降低物欲。活着才是最重要的,现在想想真的后怕
如何排解工作中的焦虑
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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