PostgreSQL ROW_NUMBER OVER()的用法说明( 二 )


 5 | 周润发 | 化学 | 87 | 1
 10 | 周星驰 | 化学 | 83 | 2
 15 | 黎明 | 化学 | 78 | 3
 13 | 黎明 | 外语 | 95 | 1
 8 | 周星驰 | 外语 | 88 | 2
 3 | 周润发 | 外语 | 67 | 3
 2 | 周润发 | 数学 | 99 | 1
 7 | 周星驰 | 数学 | 81 | 2
 12 | 黎明 | 数学 | 65 | 3
 14 | 黎明 | 物理 | 90 | 1
 4 | 周润发 | 物理 | 77 | 2
 9 | 周星驰 | 物理 | 68 | 3
 6 | 周星驰 | 语文 | 91 | 1
 1 | 周润发 | 语文 | 89 | 2
 11 | 黎明 | 语文 | 85 | 3
(15 rows)
【PostgreSQL ROW_NUMBER OVER()的用法说明】 
3. 获取每个科目的最高分
postgres=# select * from(select *,row_number() over(partition by course order by score desc)rn from student)t where rn=1;
 id | name | course | score | rn
—-+——–+——–+——-+—-
 5 | 周润发 | 化学 | 87 | 1
 13 | 黎明 | 外语 | 95 | 1
 2 | 周润发 | 数学 | 99 | 1
 14 | 黎明 | 物理 | 90 | 1
 6 | 周星驰 | 语文 | 91 | 1
(5 rows)
 
4. 每个科目的最低分也是一样的
postgres=# select * from(select *,row_number() over(partition by course order by score)rn from student)t where rn=1;
 id | name | course | score | rn
—-+——–+——–+——-+—-
 15 | 黎明 | 化学 | 78 | 1
 3 | 周润发 | 外语 | 67 | 1
 12 | 黎明 | 数学 | 65 | 1
 9 | 周星驰 | 物理 | 68 | 1
 11 | 黎明 | 语文 | 85 | 1
(5 rows)
 
只要在根据科目排序的时候按低到高顺序排列就好了 。
补充:SQL:postgresql中为查询结果增加一个自增序列之ROW_NUMBER () OVER ()的使用
举例说明:
SELECT ROW_NUMBER
 () OVER ( ORDER BY starttime DESC ) “id”,
 starttime AS “text”,
 starttime
FROM
 warning_products
WHERE
 pid_model = ‘结果’
 AND starttime IS NOT NULL
GROUP BY
 starttime
 
在这一段代码中:
查询语句就不说了, select …from…where
GROUP BY的作用:
这一段代码执行的结果是:

PostgreSQL ROW_NUMBER OVER()的用法说明

文章插图
如果将GROUP BY删除,那么执行结果为:
PostgreSQL ROW_NUMBER OVER()的用法说明

文章插图
可以看到查询出了两个相同starttime数据.
由此得出:
GROUP BY的作用是分类汇总.也就是说,查询结果中,starttime每一种查询结果只有一个
GROUP BY的作用:
如果将DESC换成
1() OVER ( ORDER BY starttime ASC ) “id”,
则运行结果为:
PostgreSQL ROW_NUMBER OVER()的用法说明

文章插图
相比可以发现,ORDER BY的作用为进行排序.
按照某种要求进行固定的排序
1ROW_NUMBER () OVER() “id”
先来看一下,如果把这一段删掉,运行结果:
PostgreSQL ROW_NUMBER OVER()的用法说明

文章插图
加上呢?
PostgreSQL ROW_NUMBER OVER()的用法说明

文章插图
明显的对比,我们为最终的查询结果增加了一列自增的id序列(这里id可以改名,”id”改为其他的即可)
由此得到结论,在执行带有row_number() over() “xx”的SQL语句时候,代码会先执行查询语句,然后执行over中的命令,最后为结果增加一列自增的序列.
文章来源:脚本之家
来源地址:https://www.jb51.net/article/205212.htm