SQL10 获取所有非manager的员工emp_no

1. 题目

2. 题解

简单、经典题目,建议深入理解,举一反三。

这题可以使用 JOIN 和 子查询的方式:

1、WHERE 子查询 + IN

# 子查询
SELECT e.emp_no
FROM employees e
WHERE e.emp_no NOT IN (SELECT emp_no FROM dept_manager)

2、JOIN

# JOIN 
SELECT e.emp_no
FROM employees e
LEFT JOIN dept_manager dm 
ON e.emp_no = dm.emp_no
WHERE dm.emp_no IS NULL 

这里使用 LEFT JOIN **,首选选取了全部了左表内容,使用dept_no关联右表,最后筛选JOIN之后的表,选出没有匹配到的部分。

使用 LEFT JOIN一个错误点
下面的错误原因是,LEFT JOINON 只对”右表“进行限制,因此最终的结果并没有对整张表进行过滤,而是包含了左表所有的内容。

SELECT e.emp_no
FROM employees e 
LEFT JOIN dept_manager dm
ON e.emp_no = dm.emp_no AND dm.emp_no IS NULL 

小结

LEFT JOIN + IS NULL 基本可以与 WHERE 子查询 + IN 等价。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值