加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Postgresql:使用窗口函数对组大小进行分组

发布时间:2020-12-13 15:54:35 所属栏目:百科 来源:网络整理
导读:在 Postgresql中是否有一种方法可以编写一个查询,该查询根据具有限制的列对行进行分组而不丢弃其他行. 假设我有一个包含三列id,color,score以及以下行的表 1 red 10.02 red 7.03 red 3.04 blue 5.05 green 4.06 blue 2.07 blue 1.0 我可以通过以下查询获得基
在 Postgresql中是否有一种方法可以编写一个查询,该查询根据具有限制的列对行进行分组而不丢弃其他行.

假设我有一个包含三列id,color,score以及以下行的表

1 red 10.0
2 red 7.0
3 red 3.0
4 blue 5.0
5 green 4.0
6 blue 2.0
7 blue 1.0

我可以通过以下查询获得基于颜色的窗口函数分组

SELECT * FROM (
    SELECT id,score,rank()
    OVER (PARTITION BY color ORDER BY score DESC)
    FROM grouping_test
) AS foo WHERE rank <= 2;

结果

id | color | score | rank 
 ----+-------+-------+------
   4 | blue  |   5.0 |    1
   6 | blue  |   2.0 |    2
   5 | green |   4.0 |    1
   1 | red   |  10.0 |    1
   2 | red   |   7.0 |    2

丢弃具有等级>的项目但是,我需要的是一个结果

1 red 10.0
2 red 7.0
4 blue 5.0
6 blue 2.0
5 green 4.0
3 red 3.0
7 blue 1.0

没有丢弃的行.

编辑:
更准确地说我需要的逻辑:

>让我获得最高分的排名
>下一行具有相同的颜色和最高分
>剩余项目得分最高的项目
>与2.相同,但对于3的行.

只要可以找到具有相同颜色的对,然后按降序分数排序.

可以在here找到测试表的import语句.
谢谢你的帮助.

解决方法

它可以使用两个嵌套的窗口函数来完成

SELECT
  id
FROM (
  SELECT
    id,((rank() OVER color_window) - 1) / 2 AS rank_window_id
  FROM grouping_test
  WINDOW color_window AS (PARTITION BY color ORDER BY score DESC)
) as foo
WINDOW rank_window AS (PARTITION BY (color,rank_window_id))
ORDER BY
  (max(score) OVER rank_window) DESC,color;

2是组大小的参数.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读