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)