gpt4 book ai didi

sql - 生成连续日期的 sql 临时表以进行左外连接

转载 作者:行者123 更新时间:2023-12-03 01:27:29 24 4
gpt4 key购买 nike

我有一个数据表,我想通过存储过程选择该数据表,以便用户可以将 MS Excel 前端连接到它并使用原始数据作为图表源。

表的原始数据的问题在于日期中存在间隙,因为如果给定日期没有数据(没有该日期的记录),那么当用户尝试绘制图表时就会产生问题。

我也想更新我的存储过程,将其左外连接到日期临时表,以便右侧将以空值形式出现,我可以将其转换为零,以便获得简单的绘图体验。

如何最好地生成开始日期和结束日期之间的单字段日期表?

最佳答案

在 SQL Server 2005 及更高版本中,您可以使用类似以下内容(公共(public)表表达式 CTE)来执行此操作:

DECLARE @DateFrom DATETIME
SET @DateFrom = '2011-01-01'

DECLARE @DateTo DATETIME
SET @DateTo = '2011-01-10'

;WITH DateRanges AS
(
SELECT @DateFrom AS 'DateValue'
UNION ALL
SELECT DATEADD(DAY, 1, DateValue)
FROM DateRanges
WHERE DateValue < @DateTo
)
SELECT * FROM DateRanges

您可以针对您的表LEFT OUTER JOIN此 CTE 并返回结果。

关于sql - 生成连续日期的 sql 临时表以进行左外连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4737378/

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