1

我需要检查表格中的大量数据,以确保我的提要没有跳过任何内容。

基本上该表具有以下列

ID 日期时间 价格

DateTime 列中的数据在每个连续行中增加 1 分钟。我需要检查当前行的下一行,看看是否比该特定上下文中的查询高 1 分钟。

查询可能需要某种循环,然后获取下一行的副本并将其与当前的日期时间行进行比较,以确保它增加了 1 分钟。

4

2 回答 2

3

我创建了一个测试表来匹配您的描述,并在每行之间插入 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 查找应该在下一分钟找到的记录。表的最后一条记录当然会报告下一行丢失,因为它还没有被插入。

于 2013-05-11T21:37:39.730 回答
1

借用 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 
于 2013-05-11T21:43:38.280 回答