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