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的作用:
这一段代码执行的结果是:

文章插图
如果将GROUP BY删除,那么执行结果为:

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

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

文章插图
加上呢?

文章插图
明显的对比,我们为最终的查询结果增加了一列自增的id序列(这里id可以改名,”id”改为其他的即可)
由此得到结论,在执行带有row_number() over() “xx”的SQL语句时候,代码会先执行查询语句,然后执行over中的命令,最后为结果增加一列自增的序列.
文章来源:脚本之家
来源地址:https://www.jb51.net/article/205212.htm
- PostgreSQL 添加各种约束语法的操作
- postgresql 中的序列nextval详解
- PostgreSQL 序列绑定字段与不绑定字段的区别说明
- PostgreSQL字符切割:substring函数的用法说明
- PostgreSQL 字符串处理与日期处理操作
- postgresql 中的to_char常用操作
- postgresql 中position函数的性能详解
- PostGreSql 判断字符串中是否有中文的案例
- rowe是什么牌子的车?rowe的车贵吗
- 一个皇冠的是什么车?crown是什么牌子