gpt4 book ai didi

sql - T-SQL - 范围内的过滤日期

转载 作者:行者123 更新时间:2023-12-02 23:55:57 25 4
gpt4 key购买 nike

代码:

DECLARE @T1 TABLE ([ID] INT, [WD] DATE, [SD] DATETIME, [ED] DATETIME, [Val] INT)
INSERT INTO @T1 ( [ID], [WD], [SD], [ED], [VAL] )
VALUES ( 1, '2016-02-14', '2016-02-14 08:00:00', '2016-02-14 16:30:00', 12 )
,( 1, '2016-02-14', '2016-02-16 08:00:00', '2016-02-16 16:30:00', 15 )
,( 3, '2016-02-14', '2016-02-16 08:00:00', '2016-02-16 16:30:00', 12 )
,( 1, '2016-02-21', '2016-02-22 08:00:00', '2016-02-22 16:30:00', 100 )
,( 2, '2016-02-21', '2016-02-25 08:00:00', '2016-02-25 16:30:00', 124 )
,( 3, '2016-03-20', '2016-03-21 08:00:00', '2016-03-21 16:30:00', 10 )
,( 3, '2016-04-17', '2016-04-17 08:00:00', '2016-04-17 16:30:00', 8 );

DECLARE @StartDate DATE
, @EndDate DATE;

SELECT @StartDate = MIN(WD) FROM @T1
SELECT @EndDate = DATEADD(DAY,6,MAX(WD)) FROM @T1;

DECLARE @T2 TABLE (D DATE) -- Table generated to get ALL dates between the minium WD (Min Sunday) and 6 days after the maximum WD (Max Sunday + 6 days to complete the week date range)
INSERT INTO @T2 ( [D] )
SELECT DATEADD(DAY, NBR - 1, @StartDate)
FROM ( SELECT ROW_NUMBER() OVER ( ORDER BY c.object_id ) AS NBR
FROM sys.columns c
) NBR
WHERE NBR - 1 <= DATEDIFF(DAY, @StartDate, @EndDate);

SELECT * FROM @T1;
SELECT * FROM @T2;

描述:@T1 是具有特定日期的预填充源数据表,其中 [ID] = 某种 ID 字段,[WD] = 一周的不同开始(星期日),[SD] = 该 [WD] 中一天的开始] 周,[ED] = 该 [WD] 周内的一天结束,[Val] = 为该 ID/WD/SD/ED 记录分配的一些值

@T2 是我定义和填充的表,用于获取 MIN([WD]) 和 MAX([WD]) + 6 天(完成一周)内的所有日期

目标:

返回 @T1 数据以及 [ID]/[WD] 周的任何缺失日期。 (请参阅所需输出以更好地理解)

所需的结果(从 Excel 复制,因此格式不同,但没关系)

[ID][WD]        [SD]            [ED]            [Val]
1 2/14/2016 2/14/16 8:00 2/14/16 16:30 12
1 2/14/2016 2/15/16 00:00 2/15/16 00:00 NULL
1 2/14/2016 2/16/16 8:00 2/16/16 16:30 15
1 2/14/2016 2/17/16 00:00 2/17/16 00:00 NULL
1 2/14/2016 2/18/16 00:00 2/18/16 00:00 NULL
1 2/14/2016 2/19/16 00:00 2/19/16 00:00 NULL
1 2/14/2016 2/20/16 00:00 2/20/16 00:00 NULL
3 2/14/2016 2/14/16 00:00 2/14/16 00:00 NULL
3 2/14/2016 2/15/16 00:00 2/15/16 00:00 NULL
3 2/14/2016 2/16/16 8:00 2/16/16 16:30 12
3 2/14/2016 2/17/16 00:00 2/17/16 00:00 NULL
3 2/14/2016 2/18/16 00:00 2/18/16 00:00 NULL
3 2/14/2016 2/19/16 00:00 2/19/16 00:00 NULL
3 2/14/2016 2/20/16 00:00 2/20/16 00:00 NULL
1 2/21/2016 2/21/16 00:00 2/21/16 00:00 NULL
1 2/21/2016 2/22/16 8:00 2/22/16 16:30 100
1 2/21/2016 2/23/16 00:00 2/23/16 00:00 NULL
1 2/21/2016 2/24/16 00:00 2/24/16 00:00 NULL
1 2/21/2016 2/25/16 00:00 2/25/16 00:00 NULL
1 2/21/2016 2/26/16 00:00 2/26/16 00:00 NULL
1 2/21/2016 2/27/16 00:00 2/27/16 00:00 NULL
2 2/21/2016 2/21/16 00:00 2/21/16 00:00 NULL
2 2/21/2016 2/22/16 00:00 2/22/16 00:00 NULL
2 2/21/2016 2/23/16 00:00 2/23/16 00:00 NULL
2 2/21/2016 2/24/16 00:00 2/24/16 00:00 NULL
2 2/21/2016 2/25/16 8:00 2/25/16 16:30 124
2 2/21/2016 2/26/16 00:00 2/26/16 00:00 NULL
2 2/21/2016 2/27/16 00:00 2/27/16 00:00 NULL
3 3/20/2016 3/20/16 00:00 3/20/16 00:00 NULL
3 3/20/2016 3/21/16 8:00 3/21/16 16:30 10
3 3/20/2016 3/22/16 00:00 3/22/16 00:00 NULL
3 3/20/2016 3/23/16 00:00 3/23/16 00:00 NULL
3 3/20/2016 3/24/16 00:00 3/24/16 00:00 NULL
3 3/20/2016 3/25/16 00:00 3/25/16 00:00 NULL
3 3/20/2016 3/26/16 00:00 3/26/16 00:00 NULL
3 4/17/2016 4/17/16 8:00 4/17/16 16:30 8
3 4/17/2016 4/18/16 00:00 4/18/16 00:00 NULL
3 4/17/2016 4/19/16 00:00 4/19/16 00:00 NULL
3 4/17/2016 4/20/16 00:00 4/20/16 00:00 NULL
3 4/17/2016 4/21/16 00:00 4/21/16 00:00 NULL
3 4/17/2016 4/22/16 00:00 4/22/16 00:00 NULL
3 4/17/2016 4/23/16 00:00 4/23/16 00:00 NULL

我尝试使用交叉连接等,但没有获得所需的输出。

最佳答案

我删除了您的@T2,并使用我的@T3。

DECLARE @T1 TABLE ([ID] INT, [WD] DATE, [SD] DATETIME, [ED] DATETIME, [Val] INT)
INSERT INTO @T1 ( [ID], [WD], [SD], [ED], [VAL] )
VALUES ( 1, '2016-02-14', '2016-02-14 08:00:00', '2016-02-14 16:30:00', 12 )
,( 1, '2016-02-14', '2016-02-16 08:00:00', '2016-02-16 16:30:00', 15 )
,( 3, '2016-02-14', '2016-02-16 08:00:00', '2016-02-16 16:30:00', 12 )
,( 1, '2016-02-21', '2016-02-22 08:00:00', '2016-02-22 16:30:00', 100 )
,( 2, '2016-02-21', '2016-02-25 08:00:00', '2016-02-25 16:30:00', 124 )
,( 3, '2016-03-20', '2016-03-21 08:00:00', '2016-03-21 16:30:00', 10 )
,( 3, '2016-04-17', '2016-04-17 08:00:00', '2016-04-17 16:30:00', 8 );

DECLARE @T3 TABLE ([ID] INT, [WD] DATE, [SD] DATETIME, [ED] DATETIME);
WITH cte AS (
SELECT DISTINCT ID, WD
FROM
@T1
)
INSERT INTO @T3 (ID, WD, SD, ED)
SELECT ID, WD, DATEADD(DAY,n,WD), DATEADD(DAY,n,WD)
FROM
cte
CROSS JOIN (VALUES (0),(1),(2),(3),(4),(5),(6)) AS ADDED(n);

SELECT t3.ID, t3.WD,COALESCE(t1.SD,t3.SD) AS SD, COALESCE(t1.ED,t3.ED) AS ED, t1.Val
FROM @T3 t3
LEFT JOIN @T1 t1 ON t3.ID=t1.ID AND CONVERT(DATE,t1.SD)=CONVERT(DATE,t3.SD)

关于sql - T-SQL - 范围内的过滤日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41385810/

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