Đây là một dạng vấn đề về khoảng trống và đảo. Bạn có thể sử dụng lag()
và sau đó là tổng tích lũy:
select id, min(laufd), max(nextdt),
row_number() over (partition by id order by min(laufd)) as period
from (select t.*,
sum(case when prev_nextdt >= laufd - interval '2' day then 0 else 1 end) over
(partition by id order by order_row) as grp
from (select t.*,
lag(nextdt) over (partition by id order by order_row) as prev_nextdt
from t
) t
) t
group by grp, id;
CHỈNH SỬA:
Nếu các giá trị được lưu trữ dưới dạng chuỗi, thì hãy sử dụng:
select id, min(laufd), max(nextdt),
row_number() over (partition by id order by min(laufd)) as period
from (select t.*,
sum(case when prev_nextdt >= laufd - interval '2' day then 0 else 1 end) over
(partition by id order by order_row) as grp
from (select t.id, t.order_row, -- any other columns you need
to_date(laufd, 'YYYYMMDD') as laufd,
to_date(nextdt, 'YYYYMMDD') as next_dt,
lag(to_date(nextdt, 'YYYYMMDD')) over (partition by id order by order_row) as prev_nextdt
from t
) t
) t
group by grp, id;