数据库SQL实战 —— 获取所有员工当前的manager

版权声明:最终解释权归属Hern所有,恒! https://blog.csdn.net/qq_36761831/article/details/83182221

时间限制:1秒 空间限制:32768K

题目描述

获取所有员工当前的manager,如果当前的manager是自己的话结果不显示,当前表示to_date='9999-01-01'。
结果第一列给出当前员工的emp_no,第二列给出其manager对应的manager_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 `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`));

输入描述:

输出描述:

emp_no manager_no
10001 10002
10003 10004
10009 10010

输入

输出

我的代码

运行时间:19ms    占用内存:3408k

SELECT dept_emp.emp_no, dept_manager.emp_no AS manager_no
FROM dept_emp, dept_manager
WHERE DATE(dept_manager.to_date) = '9999-01-01'
    AND dept_emp.dept_no = dept_manager.dept_no
    AND dept_emp.emp_no != dept_manager.emp_no;

猜你喜欢

转载自blog.csdn.net/qq_36761831/article/details/83182221
今日推荐