Postgres SQL 分组直到下一行不同
Postgres SQL Group By Until Next Row Different
我在 postgres 中有以下数据:
index | item |
------+--------
10 | aaa |
20 | aaa |
30 | bbb |
40 | aaa |
50 | aaa |
我想对它进行分组并得到最小值和最大值。但是,它只应该分组直到下一行是不同的项目。
期望:
indexMin | indexMax | item |
---------+----------+----------
10 | 20 | aaa |
30 | 30 | bbb |
40 | 50 | aaa |
可以指导一下吗?
这是一个 gaps-and-islands 问题,您希望将“相邻”行组合在一起。这里,最简单的方法是使用行号之间的差异来标识组:
select min(idx) min_idx, max(idx) max_idx, item
from (
select
t.*,
row_number() over(order by idx) rn1,
row_number() over(partition by item order by idx) rn2
from mytable t
) t
group by item, rn1 - rn2
order by min(idx)
我在 postgres 中有以下数据:
index | item |
------+--------
10 | aaa |
20 | aaa |
30 | bbb |
40 | aaa |
50 | aaa |
我想对它进行分组并得到最小值和最大值。但是,它只应该分组直到下一行是不同的项目。
期望:
indexMin | indexMax | item |
---------+----------+----------
10 | 20 | aaa |
30 | 30 | bbb |
40 | 50 | aaa |
可以指导一下吗?
这是一个 gaps-and-islands 问题,您希望将“相邻”行组合在一起。这里,最简单的方法是使用行号之间的差异来标识组:
select min(idx) min_idx, max(idx) max_idx, item
from (
select
t.*,
row_number() over(order by idx) rn1,
row_number() over(partition by item order by idx) rn2
from mytable t
) t
group by item, rn1 - rn2
order by min(idx)