我有一组日期范围,包含部分重叠和完全重叠的日期,就像这样:
UserID StartDate EndDate
====== ========== ==========
1 2011-01-01 2011-01-02 <- A
1 2011-01-01 2011-01-10 <- A
1 2011-01-08 2011-02-15 <- A
1 2011-02-20 2011-03-10 <- B
2 2011-01-01 2011-01-20 <- C
2 2011-01-15 2011-01-25 <- C
使用 T-SQL,我想要为每个用户创建一个新的数据集,消除重叠数据,扩展范围并在必要时删除冗余数据,最终得到类似于以下内容:
UserID StartDate EndDate
====== ========== ==========
1 2011-01-01 2011-02-15 ('A', three rows combined, extending the range)
1 2011-02-20 2011-03-10 ('B', no change, no overlaps here)
2 2011-01-01 2011-01-25 ('C', two rows combined)
如果需要,游标是可以的,但如果我可以不使用它们那就更好了。