Oracle 的Over、Partition By函数

例:查询各部门工资前三名员工姓名
在没认识 Over 函数之前,面对这样的题目,根本不知该如何去做,只能查出全部人员的前几名工资,无法查部门的前三名
select * from
(select last_name,salary,department_id,row_number()over(partition by department_id order by salary desc) rn from employees)
where rn<=3 and department_id is not null
其中的 row_number() 有点类似于 rownum 但前者需要结合 Over 一起使用,Over 表示行号从头到尾添加上,partition by 表示以什么为分隔,一起使用就是以部门号为分隔,给各部门的员工后加上行号,然后根据行号筛选出需要的数据

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值