Oracle数据库rank()over(partition by order by)实现分组 排序 取前几数据

Oracle

1.使用 rank()over(order by)得到记录排序

根据工资排名,排名相同的时候下一个排名累加,比如第三和第四工资一样,那么第三第四排名都是3,第五排名是5而非4

dense_rank()实现的效果不累加,第五仍是4

例:select code 编号,salary 工资,rank()over(order by salary desc) 排名 from CT_OA工资

2.使用rank()over(partition by order by)实现分组  排序

每个部门的工资排名

例:员工(id,code,name,pid)       (id,职工号,姓名,部门id)
       部门(id,code,name)             (id,编号,名称)

       工资表(id,code,salary)         (id,职工号,工资)

select y.name 姓名,b.name 部门,g.salary 工资,rank()over(partition by b.name order by g.salary desc) 排名 from CT_OA员工 y 
inner join CT_OA部门 b on b.id=y.pid

inner join CT_OA工资 g on g.code=y.code

------------得到每个部门工资前3名

select * from (第二步的结果)t where 排名<=3


总结:partition by进行分组,rank+order by 进行给每个分组内的记录进行排序

row_number()和rank()有个区别:row_number()不会出现相同排序,一直递增;就算两条记录参与排序的字段的数值一样,排序也是递增


ps:Oracle的group by不能查询不参与分组的字段,使用rank()over(partition by order by)可实现类似效果

查询每个部门工资第一位

实现mySQL:

SELECT t.name as 姓名,b.name as 部门,max(g.salary) as 工资 from CT_OA员工 t 
inner join CT_OA部门 b on b.id=t.pid 
inner join CT_OA工资 g on g.code=t.code

GROUP BY b.name 

而Oracle则是在第三步将"排名<=3" 改为"排名<=1"即可


  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OracleRANK()函数是一种分析函数,它允许我们对查询结果进行排名。当我们需要根据某个列中的值进行排序并为每个排名分配一个值时,可以使用RANK()函数。 使用RANK()函数时,我们可以选择在PARTITION BY子句中指定一个或多个列,以便根据这些列对数据进行分组。然后,我们可以使用ORDER BY子句指定一个或多个列来确定分组内的排序顺序。 RANK()函数将为每个分组内的行分配一个排名值,其中具有相同值的行将被分配相同的排名。下一个排名值将根据排序顺序和定义的分组确定。 例如: SELECT employee_id, department_id, salary, RANK() OVER (PARTITION BY department_id ORDER BY salary DESC) AS rank FROM employees; 在上面的查询中,我们对"employees"表中的salary列进行降序排序,并使用department_id进行分组RANK()函数将为每个部门内的行分配一个排名值,排名值由salary决定。排名值相同的行将被分配相同的排名。 分析函数的结果是原始查询的结果集,其中包含额外的分析函数列。通过使用分析函数,我们可以轻松地查找在每个分组内的行的排名,以及每个分组的其他信息。 在使用RANK()函数时,必须注意定义适当的排序顺序和分组列,以确保我们得到预期的结果。此外,分析函数只能在SELECT语句中使用,不能在WHERE或HAVING子句中使用。 总之,OracleRANK()函数是一种强大的分析函数,它允许我们对查询结果进行排名并为每个排名分配一个值。通过合理使用RANK()函数,我们可以便捷地获取需要的分组内的行的排名信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值