Oracle数据先进行分组后再对每组数据排序取最大最小值

该文介绍了如何利用SQL的OVER()函数配合PARTITIONBY进行数据分组,以及使用ORDERBY对每组数据进行排序,通过ROW_NUMBER()函数标记行号,然后选取行标为1的数据来获取每组的第一行,以此达到提取每组最大值或最小值的目的。
  • 先说思路。

  • 先把数据按某个字段分组,再取每组数据的第一行数据得到想要的数据。

  • 怎么分组?如何取第一行数据?第一行数据是想要的数据吗?这几个问题解决了就差不多了。

  1. over()在什么条件之上;

  1. partition by 按哪个字段划分组(如果要分组必须,有此关键字partition);

  1. order by 按哪个字段排序;

select * from (
SELECT ROW_NUMBER()over(PARTITION by 分组字段 ORDER BY 排序字段 DESC) as ro,
v.查询字段,v.查询字段
from 查询表名 v
) dual  where ro=1

每组的数据是降序排列,这样第一行数据就是最大值,反之就是最小值。

上面的sql就是把每组的数据先查出来,同时给这些数据一个行标。最后把行标为1的数据取出来得到想要的数据,满足了需求。知道的就这些,工作遇到的问题分享一下,有用点个赞。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值