У меня есть таблица с датами начала и окончания, например, ниже
drop table if exists #Temp
select *
into #Temp
from (values (1, 1, '2011-10-09', '2011-10-20'),
(2, 1, '2011-10-14', '2011-10-30'),
(3, 1, '2012-05-21', '2012-05-25')
) as value (id, userId, d1, d2)
, которая дает мне эту исходную таблицу:
id userId d1 d2
1 1 2011-10-09 2011-10-20
2 1 2011-10-14 2011-10-30
3 1 2012-05-21 2012-05-25
Проблема : я пытаюсь добиться того, чтобы получить 3 интервала из этих двух перекрывающихся дат.Как этого добиться?
select *
from
#Temp t1
join #Temp t2
on t1.userId = t2.userId
and t1.id != t2.id
where
t1.d1 <= t2.d2
and t1.d2 >= t2.d1
order by t1.d1
дает мне
id userId d1 d2 id userId d1 d2
1 1 2011-10-09 2011-10-20 2 1 2011-10-14 2011-10-30
2 1 2011-10-14 2011-10-30 1 1 2011-10-09 2011-10-20
Я не уверен, как продолжить отсюда.
Что я хочу достичь, это следующеетаблица, где разделены перекрытия.
Ожидаемый результат:
userId d1 d2
1 2011-10-09 2011-10-14
1 2011-10-14 2011-10-20
1 2011-10-20 2011-10-30
1 2012-05-21 2012-05-25