先说思路。
先把数据按某个字段分组,再取每组数据的第一行数据得到想要的数据。
怎么分组?如何取第一行数据?第一行数据是想要的数据吗?这几个问题解决了就差不多了。
over()在什么条件之上;
partition by 按哪个字段划分组(如果要分组必须,有此关键字partition);
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的数据取出来得到想要的数据,满足了需求。知道的就这些,工作遇到的问题分享一下,有用点个赞。
该文介绍了如何利用SQL的OVER()函数配合PARTITIONBY进行数据分组,以及使用ORDERBY对每组数据进行排序,通过ROW_NUMBER()函数标记行号,然后选取行标为1的数据来获取每组的第一行,以此达到提取每组最大值或最小值的目的。

1810

被折叠的 条评论
为什么被折叠?



