sql - 从 SQL 表中查找不连续性

标签 sql sql-server sql-server-2008 tsql

我的问题可能有一个非常简单的解决方案,但我很难为其制定一个好的搜索短语。我有一个包含时间戳和计数的表:

2013-08-15 14:43:58.447    5
2013-08-15 14:44:58.307    12
2013-08-15 14:45:58.383    14
2013-08-15 14:46:58.180    0
2013-08-15 14:47:58.210    4
2013-08-15 14:48:58.287    6
2013-08-15 14:49:58.550    12
2013-08-15 14:50:58.440    2
2013-08-15 14:51:58.390    5

正如您所看到的,计数会增加,然后偶尔会清空。搜索 count = 0 的行很容易,但有时在记录零计数之前计数会增加。 14:49 时计数为 12,然后重置为 0,并在 14:50 下一次记录之前增加到 2。

我需要列出计数小于之前计数的时间戳:

2013-08-15 14:46:58.180    0
2013-08-15 14:50:58.440    2

我开始对表本身进行联接,以比较两行,但 SQL 很快就变得非常困惑。

最佳答案

它的作用是根据 ts(日期时间)列创建行号,然后更容易连接到上一个条目。然后,它比较时间和计数以查找异常。

;with cte as 
(
    select * ,
      ROW_NUMBER() over (order by ts) rn    
    from yourtable
)
    select c1.* from cte c1
        inner join cte c2
            on c1.rn=c2.rn+1
            and c1.c < c2.c

关于sql - 从 SQL 表中查找不连续性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18253136/

相关文章:

sql - 通过 SQL Developer 连接时出现 ora-12505 错误

sql - 查找数组结构的第一个和最后一个

sql-server - 修改 MSDB 存储过程的好习惯?

sql-server - 如何模拟数据库连接超时

sql-server-2008 - SQL 2008 Express 是否支持更改跟踪

java - 如何使用jooq来表达mysql REGEXP?

sql - 表变量在 sql server 2008 r2 上线程安全吗?

sql-server - ADO 与 OLE DB 有什么关系?

sql-server - 有没有办法为所有 AZURES SQL DB 创建用户 dbo?

sql-server-2008 - 如果所有行都为空,则隐藏列