即使没有数据,如何在 SQL 中取回两个日期之间的整个日期范围?

2024-01-29

尝试获取数据库中的事件数量,格式为:

date   numberOfIncidents
date   numberOfIncidents
date   numberOfIncidents
date   numberOfIncidents

我向 SQL 存储过程提供开始日期/结束日期,但如果数据库中没有特定日期的条目(因为没有发生任何事件),那么我将无法获取完整范围。

我想要的是返回开始/结束日期之间的每个日期,并在其旁边有一个值。

这在 SQL Server 中可能吗?


您可以使用递归公用表表达式 http://msdn.microsoft.com/en-us/library/ms175972.aspx生成日期范围,然后将其加入到您的事件中。

WITH DateRange(date) AS
(
  SELECT @dateFrom date
  UNION ALL
  SELECT DATEADD(dd, 1, date) date FROM DateRange WHERE date < @dateTo
)

SELECT DateRange.date, count(incident.id) 
FROM DateRange
LEFT OUTER JOIN incident
  ON incident.date >= DateRange.date 
  AND incident.date < DATEADD(dd, 1, DateRange.date)
GROUP BY DateRange.date
ORDER BY DateRange.date

默认情况下,SQL Server 将递归定义限制为 100 行。如果您需要超过 100 个日期行,请附加OPTION (MAXRECURSION n)到查询末尾,更改n到所需的行数。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

即使没有数据,如何在 SQL 中取回两个日期之间的整个日期范围? 的相关文章

随机推荐