描述
有一个员工表dept_emp简况如下:
第一行表示为员工编号为10001的部门是d001部门。
有一个部门经理表dept_manager简况如下:
第一行表示为d001部门的经理是编号为10002的员工。
获取所有的员工和员工对应的经理,如果员工本身是经理的话则不显示,以上例子如下:
/*题目:获取所有的员工和员工对应的经理,如果员工本身是经理的话则不显示 */
/*方法一:left join 左连接+不等于 */
select de.emp_no,dm.emp_no from dept_emp de
left join dept_manager dm
on de.dept_no = dm.dept_no
where de.emp_no <> dm.emp_no
and de.to_date='9999-01-01'
AND dm.to_date='9999-01-01'
/*方法一:left join 左连接+子查询 +not in*/
select de.emp_no,dm.emp_no from dept_emp de
left join dept_manager dm
on de.dept_no = dm.dept_no
where de.to_date='9999-01-01'
AND dm.to_date='9999-01-01'
and de.emp_no not in
(select d.emp_no
from dept_manager d)