淘先锋技术网

首页 1 2 3 4 5 6 7

题目描述:查找收入比经理高的员工。

下图表头的含义解释-雇员的ID、姓名、工资和经理的ID。
在这里插入图片描述

一、解题思路一

一、将是经理和不是经理的信息分开为两张表,然后以雇员的工资数据为主,左连接经理的工资,用case when 对比来返回雇员信息。

1.1 关于NULL的使用问题

【问题一】这样对比的话,出现一对多的数据对比,表连接有问题。
【问题二】在筛选出雇员信息,使用
select
row_number() over(order by salary desc) as rn
,name
,salary
from employee
where id not in (select managerid from employee)
报错,在最后Id not in 中由于managerid有null值时无法有效进行判断,该代码返回值为null
【问题三】null无法直接判断,即name != null 无法成功
【问题四】select managerid from employee where isnull(managerid)
返回的为是空null所对应的行数据

二、解题思路二

二、由于表employee结构中,最后一行的managerid和整表关联弱,要用独立思维去使用该列数据。
在这里插入图片描述
上图为【select *
from Employee as a
join Employee as b
on a.managerId = b.id】两个表关联后的表

2.1完整代码如下

select 
a.name as Employee
from Employee as a 
join Employee as b
on a.managerId = b.id
where a.salary > b.salary

另一实现代码如下,不使用join连接

select
    e1.Name AS Employee 
FROM
    Employee e1,
    Employee e2
where
    e1.ManagerId = e2.Id AND e1.Salary > e2.Salary