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 没有丢弃的行. 编辑: >让我获得最高分的排名 只要可以找到具有相同颜色的对,然后按降序分数排序. 可以在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是组大小的参数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |