11. 获取所有员工当前的manager——not in 和<>

本文介绍如何使用SQL查询从员工表和部门经理表中获取员工及其对应经理,排除经理本人,并提供两种不同查询方案。第一种使用LEFT JOIN,第二种使用INNER JOIN和条件排除。展示了两种方法的运行时间和内存消耗。

描述

有一个员工表dept_emp简况如下:

第一行表示为员工编号为10001的部门是d001部门。

有一个部门经理表dept_manager简况如下:

第一行表示为d001部门的经理是编号为10002的员工。

获取所有的员工和员工对应的经理,如果员工本身是经理的话则不显示,以上例子如下:

提交程序:

select de.emp_no ,dm.emp_no as manager
from dept_emp de
left join dept_manager dm
on de.dept_no = dm.dept_no
where de.emp_no not in (select dm.emp_no from dept_manager)

提交结果:答案正确 运行时间:20ms 占用内存:3472KB 使用语言:Sqlite 用例通过率:100.00%

SELECT e.emp_no, m.emp_no AS manager_no
FROM dept_emp AS e
INNER JOIN dept_manager AS m
ON e.dept_no=m.dept_no
WHERE e.emp_no <> m.emp_no
AND e.to_date='9999-01-01'
AND m.to_date='9999-01-01'

用不等于<>或!=都可以。

提交结果:答案正确 运行时间:16ms 占用内存:3428KB 使用语言:Sqlite 用例通过率:100.00%

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值