Nếu bạn chỉ muốn đánh số chúng, thì tôi đề xuất lag()
với tổng tích lũy:
select t.*,
sum(case when datefrom = dateadd(day, 1, prev_dateto
then 0 else 1
end) over (order by itemId, datefrom)
from (select t.*,
lag(dateto) over (partition by itemid order by datefrom) as prev_dateto
from table t
) t;
case
xác định nơi một hòn đảo mới bắt đầu. Tổng tích lũy chỉ tính bằng cờ này.