我需要检查表格中的大量数据,以确保我的提要没有跳过任何内容。
基本上该表具有以下列
ID 日期时间 价格
DateTime 列中的数据在每个连续行中增加 1 分钟。我需要检查当前行的下一行,看看是否比该特定上下文中的查询高 1 分钟。
查询可能需要某种循环,然后获取下一行的副本并将其与当前的日期时间行进行比较,以确保它增加了 1 分钟。
我需要检查表格中的大量数据,以确保我的提要没有跳过任何内容。
基本上该表具有以下列
ID 日期时间 价格
DateTime 列中的数据在每个连续行中增加 1 分钟。我需要检查当前行的下一行,看看是否比该特定上下文中的查询高 1 分钟。
查询可能需要某种循环,然后获取下一行的副本并将其与当前的日期时间行进行比较,以确保它增加了 1 分钟。
我创建了一个测试表来匹配您的描述,并在每行之间插入 100 行,如下所示:
CREATE TABLE [Test] ([Id] int IDENTITY(1,1), [Date] datetime, [Price] int);
WITH [Tally] AS (
SELECT GETDATE() AS [Date]
UNION ALL
SELECT DATEADD(minute, -1, [Date]) FROM [Tally] WHERE [Date] > DATEADD(minute, -99, GETDATE())
)
INSERT INTO [Test] ([Date], [Price])
SELECT [Date], 123 AS [Price]
FROM [Tally]
然后我在中间删除了一条记录以模拟丢失的一分钟:
DELETE FROM [Test]
WHERE Id = 50
现在我们可以使用这个查询来查找丢失的记录:
SELECT
a.*
,CASE WHEN b.[Id] IS NULL THEN 'Next record is Missing!' ELSE CAST(b.[Id] as varchar) END AS NextId
FROM
[Test] AS a
LEFT JOIN [Test] AS b ON a.[Date] = DATEADD(minute,1,b.[Date])
WHERE
b.[Id] IS NULL
结果将如下所示:
Id Date Price NextId
----------- ----------------------- ----------- ------------------------------
49 2013-05-11 22:42:56.440 123 Next record is Missing!
100 2013-05-11 21:51:56.440 123 Next record is Missing!
(2 row(s) affected)
该问题的关键解决方案是将表与自身连接,但使用 datediff 查找应该在下一分钟找到的记录。表的最后一条记录当然会报告下一行丢失,因为它还没有被插入。
借用 TheQ 的样本数据,您可以使用
WITH T
AS (SELECT *,
DATEDIFF(MINUTE, '20000101', [Date]) -
DENSE_RANK() OVER (ORDER BY [Date]) AS G
FROM Test)
SELECT MIN([Date]) AS StartIsland,
MAX([Date]) AS EndIsland
FROM T
GROUP BY G