题目描述:查找收入比经理高的员工。
下图表头的含义解释-雇员的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