oracle的分组排序函数(窗口函数)

本文详细介绍了SQL中的窗口函数row_number(),包括两种不同的写法及其使用场景。重点讲解了如何通过row_number()进行数据分组、排序,并在where、groupby、orderby之后执行。同时,给出了按姓名分组、按日期降序排序并去重的实例,展示了row_number()在数据处理中的重要作用。
摘要由CSDN通过智能技术生成

第一种写法:
row_number() over(partition by 一个或多个分组列 order by 一个或多个排序列 asc/desc) as 别名
//如果不写asc/desc的话,默认为asc

第二种写法:
row_number() over(distribute by 一个或多个分组列 sort by 一个或多个排序列 asc/desc) as 别名

在使用 row_number() over()函数时候,
over()里头的分组以及排序的执行晚于 where 、group by、 order by 的执行。

rn:为别名,代表每个分组中每行数据的所在序号ID,可用于根据rn序号ID直接获取出每个分组中的第一条数据

例子:按name分组,按日期排序

select
    *,
    row_number() over(distribute by name sort by date desc) rn
from
    table_A
;

常使用该函数进行去重

SELECT
	*
FROM
	(
	SELECT
	    a.*,
	    row_number() over(partition by name order by create_time desc) as rn 
	FROM
	    table_A a 
	)
WHERE
	rn=1
;

解释:按name分组,然后按数据创建时间降序排序,最后去rn=1就是取最新的一条数据,这也是一种去重的办法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值