高频 SQL 50 题(基础版)| 176. 第二高的薪水

Employee 表:

±------------±-----+
| Column Name | Type |
±------------±-----+
| id | int |
| salary | int |
±------------±-----+
id 是这个表的主键。
表的每一行包含员工的工资信息。

查询并返回 Employee 表中第二高的 不同 薪水 。如果不存在第二高的薪水,查询应该返回 null(Pandas 则返回 None) 。

查询结果如下例所示。

示例 1:

输入:
Employee 表:
±—±-------+
| id | salary |
±—±-------+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
±—±-------+
输出:
±--------------------+
| SecondHighestSalary |
±--------------------+
| 200 |
±--------------------+

示例 2:

输入:
Employee 表:
±—±-------+
| id | salary |
±—±-------+
| 1 | 100 |
±—±-------+
输出:
±--------------------+
| SecondHighestSalary |
±--------------------+
| null |
±--------------------+

-- 解1:排除最高的薪水后从剩余数据中求出最大的便是第二稿
SELECT max( Salary ) SecondHighestSalary 
FROM Employee 
WHERE Salary < (SELECT max( Salary )FROM Employee)
-- 解2:使用开窗函数进行排名,得出第二高薪水,
-- 在套一层select应对不存在第二高的薪水应该返回 null的情况
SELECT( SELECT salary FROM(
	SELECT 
		DISTINCT(salary),
		dense_rank()  OVER (ORDER BY salary desc)  as rk
	FROM Employee) t
	where rk = 2
) as SecondHighestSalary
-- 解3 对薪资进行降序排序并去重,然后使用limit 偏移取第二高薪水
-- 在套一层select应对不存在第二高的薪水应该返回 null的情况
SELECT ( SELECT DISTINCT Salary FROM Employee ORDER BY salary DESC LIMIT 1, 1 ) AS SecondHighestSalary
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值