sql - 如何在两个日期之间恢复 SQL 中的整个日期范围,即使没有数据?

标签 sql sql-server

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

date   numberOfIncidents
date   numberOfIncidents
date   numberOfIncidents
date   numberOfIncidents

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

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

这在 SQL Server 中可能吗?

最佳答案

您可以使用递归 common table expression生成日期范围,然后将其加入您的事件。

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 更改为所需的行数。

关于sql - 如何在两个日期之间恢复 SQL 中的整个日期范围,即使没有数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1921818/

相关文章:

mysql - 如何根据条件选择要进行内连接的表

sql - 如何在 SQL 中使用 "NOT LIKE"作为列值

sql - 使用 SQL 在字符串中存储超过 8000 个字符

SQL Server - 具有相关性的条件聚合

mysql - SQL技巧按月计算行数?

c# - 需要递归查找。 DB 与 C# GUI

sql - SSIS使用for循环容器不执行脚本任务和数据流任务

sql-server - 如何将Sql列转换为行?

sql-server - 如何将结果合并到一条线上

c# - 从 SQL Server 自动填充 smartsheet 中的行