sql row_number() over(partition by AAA order by BBB desc) rn 的用法和解释。(ORACLE)
情景:获取一些数据中某些字段(AAA)相同 某个字段(BBB)最大的一系列值
比如:获取一个班级每个学生一学期中几次考试语文科目中分数最高一次的信息
学生姓名或者id就是AAA 语文分数就是BBB
select a.* from
(select afr.GROUP_ID,group_NM, aff.*,cp.counterparty_nm, row_number() over(partition by afr.COUNTERPARTY_CD order by afr.GROUP_ID desc) rn
from AFF_RATE_PRICING_CP aff
left join cpm_cp cp on aff.counterparty_cd=cp.counterparty_cd
left join aff_rate_pricing_acct_grouplnk afr on afr.COUNTERPARTY_CD = aff.counterparty_cd
left join aff_rate_pricing_acct_group arp on afr.group_ID = arp.group_ID) a
where a.PRICING_ID='013' and a.RN = 1
row_number() over(partition by AAA order by BBB desc) rn rn 会对BBB生成一个排序 再通过rn=1就获得了最大值