MySQL练习十五:查询员工的部门领导编号和自身的编号

卡二条的技术圈

共 1547字,需浏览 4分钟

 ·

2021-09-30 18:47

题目:有一个员工表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

此题在牛客网上存在一点争议,推荐写法根据评论,在原题上是有考虑在职和不在职的情况。不过两种方式够给通过了。


浏览 96
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报