首页 > 代码库 > row_number()函数
row_number()函数
row_number()over( partition by a order by b desc ) rn
根据【字段a】分组,分组内根据【字段b】排序,次函数返回的是每组内部排序后的序列号(分组内唯一不重复排序)
例子:
一张表,求按date,pay排序后的数据,且每天数据只有3条
select datetime,type,pay from (select row_number()over(partition by datetime order by pay) c_index,t_e.* from t_e )a where a.c_index <= 3
---------------------------------------------------------------------------------------------------------------------------------------------
扩展:
row_number()和rownum差不多,功能更强一点(可以在各个分组内从1开时排序).
rank()是跳跃排序,有两个第二名时接下来就是第四名(同样是在各个分组内).
dense_rank()是连续排序,有两个第二名时仍然跟着第三名。相比之下row_number是没有重复值的 .
row_number()函数
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。