1 2

oracle 根据字段分组取第一条数据及rank函数说明

当前有这样一个需求,根据外键对子表数据进行分组,取每组中的一条数据就行了,如图:

 

 

 如:COMMANDID = 26的有两条,只取一条数据。

sql语句:

select *
  from(select SYSTEMID,COMMANDID,SUBTYPE,LISTCONTENT,STRING1,STRING2,STRING3,STRING4,STRING5,NUMBER1,NUMBER2,NUMBER3,NUMBER4,NUMBER5,
               rank() over(partition by e.commandid order by e.systemid desc) rankNo
          from COMMAND_NOFILTER_COMMANDINFO e) e
 where e.rankNo = 1 ;

解释下上面sql的意思:
rank() over(partition by e.commandid order by e.systemid desc) rankNo (
partition by 根据什么进行分组,
order by 根据什么进行排序,
rank() over() 进行排名
rankNo 别名

e.rankNo = 1 即是取排名后的第一条数据,即完成了业务需要的sql语句。

使用 rank()over(order by 字段 )得到记录排序

根据某个字段进行排名,排名相同的时候下一个排名累加,比如第三和第四一样,那么第三第四排名都是3,第五排名是5而非4,空出并列所占的名称

如:

 

 dense_rank() over与ran() over的区别:并列以后,下一位并不空出所占的名次.

 

 

 

 

posted @   大海的泡沫  阅读(4508)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
1 2
点击右上角即可分享
微信分享提示