ROW_NUMBER()为返回的记录定义个行编号, PARTITION BY col1 是根据col1分组,ORDER BY col2[ DESC ]是根据col2进行排序。
举例: 1. 根据分数排序rn是给我们的一个排序。
2. 根据科目分组,按分数排序 3. 获取每个科目的最高分 4. 每个科目的最低分也是一样的只要在根据科目排序的时候按低到高顺序排列就好了。
补充:SQL:postgresql中为查询结果增加一个自增序列之ROW_NUMBER () OVER ()的使用
举例说明: 在这一段代码中:查询语句就不说了, select …from…where
GROUP BY的作用:
这一段代码执行的结果是:
如果将GROUP BY删除,那么执行结果为:
可以看到查询出了两个相同starttime数据.
由此得出:
GROUP BY的作用是分类汇总.也就是说,查询结果中,starttime每一种查询结果只有一个
GROUP BY的作用:
如果将DESC换成
则运行结果为:
相比可以发现,ORDER BY的作用为进行排序.
按照某种要求进行固定的排序
先来看一下,如果把这一段删掉,运行结果:
加上呢?
明显的对比,我们为最终的查询结果增加了一列自增的id序列(这里id可以改名,"id"改为其他的即可)
由此得到结论,在执行带有row_number() over() "xx"的SQL语句时候,代码会先执行查询语句,然后执行over中的命令,最后为结果增加一列自增的序列.
以上为个人经验,希望能给大家一个参考,也希望大家多多支持七叶笔记。如有错误或未考虑完全的地方,望不吝赐教。