gpt4 book ai didi

sql - 使用 SQL 检测连续日期范围

转载 作者:行者123 更新时间:2023-12-01 19:58:00 28 4
gpt4 key购买 nike

我想填充需要开始和结束日期信息的日历对象。我有一列包含一系列日期。有些日期是连续的(相差一天),有些则不是。

InfoDate  

2013-12-04 consecutive date [StartDate]
2013-12-05 consecutive date
2013-12-06 consecutive date [EndDate]

2013-12-09 [startDate]
2013-12-10 [EndDate]

2014-01-01 [startDate]
2014-01-02
2014-01-03 [EndDate]

2014-01-06 [startDate]
2014-01-07 [EndDate]

2014-01-29 [startDate]
2014-01-30
2014-01-31 [EndDate]

2014-02-03 [startDate]
2014-02-04 [EndDate]

我想选择每个连续日期范围的开始日期和结束日期( block 中的第一个和最后一个日期)。

StartDate     EndDate

2013-12-04 2013-12-06
2013-12-09 2013-12-10
2014-01-01 2014-01-03
2014-01-06 2014-01-07
2014-01-29 2014-01-31
2014-02-03 2014-02-04

我想仅使用 SQL 解决问题。

最佳答案

无需连接或递归 CTE。标准的间隙和岛解决方案是按(值减去行号)进行分组,因为它在连续序列中是不变的。开始日期和结束日期只是组的 MIN() 和 MAX()。

WITH t AS (
SELECT InfoDate d,ROW_NUMBER() OVER(ORDER BY InfoDate) i
FROM @d
GROUP BY InfoDate
)
SELECT MIN(d),MAX(d)
FROM t
GROUP BY DATEDIFF(day,i,d)

关于sql - 使用 SQL 检测连续日期范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20402089/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com