微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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是组大小的参数.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐