例:查询各部门工资前三名员工姓名
在没认识 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 表示以什么为分隔,一起使用就是以部门号为分隔,给各部门的员工后加上行号,然后根据行号筛选出需要的数据
Oracle 的Over、Partition By函数
最新推荐文章于 2021-01-21 10:12:12 发布