题解 | #获取所有非manager的员工emp_no#

获取所有非manager的员工emp_no

http://www.nowcoder.com/practice/32c53d06443346f4a2f2ca733c19660c

方法一,NOT EXISTS(似乎不常用呀)

SELECT employees.emp_no FROM employees
WHERE not EXISTS(select * from dept_manager where
                dept_manager.emp_no=employees.emp_no);

方法二,用NOT IN(in关键字适合确定数量的情况,一般效率较低)

SELECT employees.emp_no FROM employees
WHERE emp_no NOT IN(select emp_no from manager);

方法三,用左连接(这个好一点)

SELECT employees.emp_no 
FROM employees LEFT OUTER JOIN manager 
ON employees.emp_no=dept_manager.emp_no
WHERE dept_no IS NULL;
全部评论
哪个速度更快一些呢?
1 回复 分享
发布于 2022-07-27 15:37
根据道理,不带子查询的,快。
点赞 回复 分享
发布于 2022-09-22 16:16 上海

相关推荐

评论
1
1
分享

创作者周榜

更多
牛客网
牛客企业服务