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/employees-earning-more-than-their-managers
解题思路:本题主要是要找出员工的Salary及员工对应经理的Salary,然后进行比较,显示出超过经理收入的员工姓名。可以看到输出结果的字段为Employee,但其字段的值显示的是员工的name值,所以需要一个 as 将其name字段起一个别名Employee。其中员工的Salary很好找,但其经理的Salary,需要通过员工的ManagerId值,再转化为其Id对应的Salary值就可以进行比较了。
注意:下面SQL语句中的Employee as a 是将其表名Employee起别名为a,方面进行SQL语句的书写(Employee as b类似)。否则Salary大于Salary就是你自己也不明白是哪个的Salary要大于哪个吧
SQL语句:
select Name as Employee from Employee as a
where a.Salary > (select Salary from Employee as b where b.Id=a.ManagerId)