row_number() over(partition by)整理

row_number() over(partition by),作为oracle常用的分析函数,身为数据开发时必须要掌握的。不过一段时间不用,难免会有些忘记,今天整理一下一些场景下的用法。

现有表(test_rownumber)有如下数据:

RUSER(用户名)  RID(用户编号) RSAL(用户消费) RDATE(日期)

row_number() over(partition by)整理_第1张图片

场景一:求每个用户最新日期的信息

先进行分区,然后按日期排序

select r.*,row_number() over(partition by r.ruser, r.rid, r.rsal order by rdate desc)
from test_rownumber r

结果如下:

row_number() over(partition by)整理_第2张图片

最后取rn=1即可得到每个用户最新日期的信息

注意:

如果不先分区,而是直接用日期排序,得到的结果如下

select r.*,row_number() over(order by rdate desc)
from test_rownumber r

row_number() over(partition by)整理_第3张图片

如果只按用户来分区,得到的结果如下

select r.*,row_number() over(partition by ruser order by rdate desc)
from test_rownumber r;--只能得到最新日期用户的一笔信息,而不是两笔

row_number() over(partition by)整理_第4张图片

 

你可能感兴趣的:(database,study)