大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说sql分组排序row_number() over(),希望您对编程的造诣更进一步.
sql分组排序函数
row_number() over(partition by 分组列 order by 排序列 desc)
select tmp.pk_order
from(select pk_order,
row_number() over(partition by vbillcode order by nversion desc) as rn
from po_order
where dr = 0
and vbillcode =‘ vbillcode‘) tmp
where tmp.rn = 1
按单据号分组,按版本号降序排列,新增做rn列,外套一层rn才可以放到where条件里面,
相同单据号取版本号最大的对应的单据号行,再获取此行主键
vbillcode 单据号 nversion 版本号 pk_主键
在使用 row_number() over()函数时候,over()里头的分组以及排序的执行晚于 where 、group by、 order by 的执行。
sql分组排序row_number() over()
原文地址:https://www.cnblogs.com/tenghao/p/14311816.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6546.html