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

标签 sql sql-server sql-server-2008 gaps-and-islands

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

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/

相关文章:

sql - 动态更新SSIS中Web服务任务中的wsdl文件

mysql - SQL 根据计算值创建新列

sql-server - 了解奇怪的数据库 key 设计

MySQL 根据上一行和下一行选择行

mysql - UPDATE值如果大于0怎么办?

c# - 将 C# 类转换为 SQL 表

c# - 结合来自数据库连接和数据服务引用的 ADO.Net 实体的 Linq 查询?

sql - 选择父子表的映射表

sql - 如果使用附加列名再次创建删除的临时表,则无法选择附加列名

sql-server-2008 - Fluent NHibernate - 总是删除表