Gebruik lag()
en cumulatieve som:
with query as (
select w.*,
sum(case when week < prev_week + 2 then 0 else 1 end) over (partition by animal order by week) as grp
from (select w.*,
lag(week) over (partition by animal order by week) as prev_week
from test.walk w
) w
)
select
animal, week, grp,
dense_rank() over (order by animal, grp) as grp2
from query
Opmerking:hierdoor wordt het aftellen voor elk dier opnieuw gestart -- wat de eigenlijke bedoeling lijkt te zijn van wat je wilt doen. De definitie van het probleem is een beetje lastig als je wilt dat de groepen gescheiden zijn per dier, maar incrementeel. Een methode is:
select w.*,
sum(case when prev_week = week then 0 else 1 end) over (order by min_week, animal, week) as grp
from (select w.*,
lag(week) over (partition by animal order by week) as prev_week,
min(week) over (partition by animal) as min_week
from test.walk w
) w;