LeetCode数据库专题
简单难度
181.超过经理收入的员工
题目
Employee 表包含所有员工,他们的经理也属于员工。每个员工都有一个 Id,此外还有一列对应员工的经理的 Id。
| Id | Name | Salary | ManagerId |
|---|---|---|---|
| 1 | Joe | 70000 | 3 |
| 2 | Henry | 80000 | 4 |
| 3 | Sam | 60000 | NULL |
| 4 | Max | 90000 | NULL |
给定 Employee 表,编写一个 SQL 查询,该查询可以获取收入超过他们经理的员工的姓名。在上面的表格中,Joe 是唯一一个收入超过他的经理的员工。
| Employee |
|---|
| Joe |
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/classes-more-than-5-students
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解答(Mysql)
--解法1 282ms 左连接
SELECT A.NAME Employee FROM Employee A
LEFT JOIN Employee B ON A.MANAGERID = B.ID
WHERE A.SALARY > B.SALARY
--解法2 380ms 笛卡尔积
SELECT A.NAME Employee FROM Employee A, Employee B
where A.MANAGERID = B.ID
and A.SALARY > B.SALARY
本文探讨了如何使用SQL查询从Employee表中筛选出那些收入超过他们经理的员工。通过两种方法实现,一是使用左连接,二是利用笛卡尔积,最终找到满足条件的员工,如案例中的Joe。
1665

被折叠的 条评论
为什么被折叠?



