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

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

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

在有group by的时候,select只能出现以下三种情况,①常量 ② group by后的字段 ③ 聚合函数。此时dept_name看上去不属于以上任何一种,但是,其实经过子查询后,它就是一个常量。因为值是唯一的,所以可以放在这里。

另外补充一下,子查询的各种情况。①值 ②行 ③ 若干行。子查询可以放的位置:①select后 ② where 后 ③当做临时表放在from后 ④ having后。

select de.dept_no,
    (select dept_name from departments d1 where d1.dept_no = de.dept_no) ,
    title, count(de.emp_no)
from dept_emp de
join  departments d on d.dept_no = de.dept_no
join titles t on t.emp_no = de.emp_no
group by de.dept_no , title
order by de.dept_no ,title 

全部评论

相关推荐

04-28 11:34
西北大学 运营
牛客4396号:不好意思,这个照片猛一看像丁真
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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