MySQL练习十五:查询员工的部门领导编号和自身的编号
题目:有一个员工表dept_emp简况如下:
第一行表示为员工编号为10001的部门是d001部门。
有一个部门经理表dept_manager简况如下:
第一行表示为d001部门的经理是编号为10002的员工。获取所有的员工和员工对应的经理,如果员工本身是经理的话则不显示,以上例子如下:
数据表:表结构
drop table if exists `dept_emp` ;
drop table if exists `dept_manager` ;
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 `dept_manager` (
`dept_no` char(4) NOT NULL,
`emp_no` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_no`));
数据:insert语句
INSERT INTO dept_emp VALUES(10001,'d001','1986-06-26','9999-01-01');
INSERT INTO dept_emp VALUES(10002,'d001','1996-08-03','9999-01-01');
INSERT INTO dept_emp VALUES(10003,'d002','1995-12-03','9999-01-01');
INSERT INTO dept_manager VALUES('d001',10002,'1996-08-03','9999-01-01');
INSERT INTO dept_manager VALUES('d002',10003,'1990-08-05','9999-01-01');
解题思路:
1、首先明确是查询员工的部门领导,部门领导的编号又在部门表中,这时候直接去查询到部门就可以得到部门信息,从而可以得到部门领导的编号。
2、考虑到如果员工属于部门领导的数据不查询出来,针对这种数据做一个过滤即可。
参考答案:
# 推荐写法
SELECT a.emp_no, b.emp_no AS manager_no
FROM dept_emp AS a INNER JOIN dept_manager AS b
ON a.dept_no = b.dept_no
WHERE b.to_date = '9999-01-01' AND a.to_date = '9999-01-01' AND a.emp_no <> b.emp_no
# 个人写法。
SELECT e.emp_no, m.emp_no AS manager
FROM dept_emp e LEFT JOIN dept_manager m
ON e.dept_no = m.dept_no
WHERE e.emp_no <> m.emp_no
此题在牛客网上存在一点争议,推荐写法根据评论,在原题上是有考虑在职和不在职的情况。不过两种方式够给通过了。
评论