Postgres SQL Группировать до следующей строки отличается - PullRequest
2 голосов
/ 05 августа 2020

У меня есть следующие данные в 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     |
  

Может ли это помочь?

1 Ответ

3 голосов
/ 05 августа 2020

Это проблема с пробелами и островками, когда вы хотите сгруппировать «смежные» строки. Здесь самый простой подход - использовать разницу между номерами строк для идентификации групп:

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)
...