Second Highest Salary

本文介绍了一种使用max函数和子查询来优化SQL查询的方法,旨在高效地找出员工表中的最大薪资,相比传统的使用ORDER BY和LIMIT方法更为节省资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用limit实现,注意边界条件,如果不存在,输出null

SELECT IFNULL((SELECT DISTINCT Salary FROM Employee ORDER BY Salary DESC LIMIT 1,1),NULL)

耗时:964 ms

上述方法并不高效,更高效的方法是:先用max函数求出最大值,再在剩下的值中取出最大值

select max(salary) from Employee where salary !=(select max(salary) from Employee)

耗时:764 ms

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值