【力扣精选】Oracle SQL 176. 第二高的薪水
【力扣精选】Oracle SQL 176. 第二高的薪水
这道题很适合用来作为窗口函数的入门使用练习
链接如下:
https://leetcode.cn/problems/second-highest-salary/description/
获取并返回 Employee 表中第二高的薪水 。如果不存在第二高的薪水,查询应该返回 null 。
如果不使用窗口函数的话,肯定也可以写出来,比如针对题目,直接比较出最大值,然后去掉最大值,那么剩下的一定是第二大的值
方法很多很多,这里可以使用窗口函数dense_rank()over()
--Oracle常用分组排序窗口函数
rank() over(order by score desc) --按照大小进行排名,纯粹的排名,相同大小名次一样,会有名次的跳跃,即除了相同的,其余排名顺序与行号相同,第一名有十个,那第十一个就是第十一名
dense_rank() over(order by score desc) --按照大小进行排名,相同大小名次一样,但是不会进行名次的跳跃,即第一名玩了就是第二名,就算第一名有十个,那第十一个也是第二名
row_number() over(order by score desc) --按照大小进行排名,相同大小名次不一样,就是按照行号走下去
结果可以参考下面的情况,直接对窗口函数的结果进行=2的操作,使用nvl,如果为空,则显示null,逻辑很清楚明白
select nvl((select t.salary from (select distinct salary,
dense_rank() over(order by salary desc) as tt
from Employee) t where t.tt = 2),NULL)
as SecondHighestSalary
from dual
您能读到这儿,我呢是发自真心的感谢您,若要转载,还望请您带上链接
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现