SQL练习:SQL26_困难
题目: 汇总各个部门当前员工的title类型的分配数目,即结果给出部门编号dept_no、dept_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);
题解
# 思路:先找出MS与ES并根据dept_no连接,最后依题意条件筛选
SELECT D.dept_no,D.dept_name,T.title,COUNT(T.title)
FROM departments D
JOIN dept_emp E ON D.dept_no = E.dept_no AND E.to_date = '9999-01-01' # 连接前指定条件
JOIN titles T ON T.emp_no = E.emp_no AND T.to_date = '9999-01-01' # 也可连接后WHERE指定
GROUP BY D.dept_no,T.title # 根据部门title分组
ORDER BY D.dept_no
- 个人整理的笔记,仅供学习使用,有问题麻烦指正。
- 题目来源于:牛客网