加入收藏 | 设为首页 | 会员中心 | 我要投稿 51站长网 (https://www.51zhanzhang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
站内搜索:
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

生成连续日期的sql临时表到左外连接到

发布时间:2021-01-20 18:12:36 所属栏目:MsSql教程 来源:网络整理
导读:我有一个数据表,我想通过存储过程选择出来,这样用户可以将MS excel前端连接到它,并使用原始数据作为图形来源. 表的原始数据的问题是日期中存在间隙,因为如果给定日期没有数据(没有该日期的记录),那么当用户尝试绘制它时会产生问题. 我想要将我的存储过程更新

我有一个数据表,我想通过存储过程选择出来,这样用户可以将MS excel前端连接到它,并使用原始数据作为图形来源.

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

我想要将我的存储过程更新到左外连接到临时表的日期,以便右侧将作为空值进入,我可以转换为零,以便他们具有简单的绘图体验.

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

解决方法

在SQL Server 2005及更高版本中,您可以使用类似这样的内容(公用表表达式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对你的表并返回结果.

(编辑:ASP站长)

【免责声明】本站内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

    相关内容
    未处理完善
      无相关信息
    未处理完善