SQL练习26:汇总各个部门当前员工的title类型的分配数目

SQL练习26:汇总各个部门当前员工的title类型的分配数目

题目链接:牛客网

题目描述
汇总各个部门当前员工的title类型的分配数目,即结果给出部门编号dept_nodept_name、其部门下所有的当前(dept_emp.to_date = '9999-01-01')员工的当前(titles.to_date = '9999-01-01')title以及该类型title对应的数目count,结果按照dept_no升序排序
(注:因为员工可能有离职,所有dept_emp里面to_date不为'9999-01-01'就已经离职了,不计入统计,而且员工可能有晋升,所以如果titles.to_date不为 '9999-01-01',那么这个可能是员工之前的职位信息,也不计入统计)。

CREATE TABLE `departments` (
`dept_no` char(4) NOT NULL,
`dept_name` varchar(40) NOT NULL,
PRIMARY KEY (`dept_no`));

CREATE TABLE `dept_emp` (
`emp_no` int(11) NOT NULL,
`dept_no` char(4) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_no`));

CREATE TABLE IF NOT EXISTS `titles` (
`emp_no` int(11) NOT NULL,
`title` varchar(50) NOT NULL,
`from_date` date NOT NULL,
`to_date` date DEFAULT NULL);

解法
根据题目的要求,可以先连接departments 表与dept_emp表,根据测试数据添加限定条件ds.dept_no = de.dept_no AND de.to_date = '9999-01-01',再连接titles表,限定条件为 de.emp_no = t.emp_no AND t.to_date = '9999-01-01'。最后用 GROUP BY 同时对 ds.dept_notitle 进行分组,使用COUNT(t.emp_no)统计相同部门下相同头衔的员工个数。

SELECT ds.dept_no, ds.dept_name, title, COUNT(t.emp_no) count
FROM (departments ds JOIN dept_emp de 
      ON ds.dept_no = de.dept_no AND de.to_date = '9999-01-01')
      JOIN titles t 
      ON de.emp_no = t.emp_no AND t.to_date = '9999-01-01'
GROUP BY ds.dept_no, title
ORDER BY dept_no

猜你喜欢

转载自blog.csdn.net/qq_43965708/article/details/113606595
今日推荐