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

从SQL表中查找不连续性

发布时间:2020-12-12 06:50:35 所属栏目:MsSql教程 来源:网络整理
导读:对我的问题可能有一个非常简单的解决方案,但我正在为它制定一个好的搜索短语.我有一个包含时间戳和计数的表: 2013-08-15 14:43:58.447 52013-08-15 14:44:58.307 122013-08-15 14:45:58.383 142013-08-15 14:46:58.180 02013-08-15 14:47:58.210 42013-08-15
对我的问题可能有一个非常简单的解决方案,但我正在为它制定一个好的搜索短语.我有一个包含时间戳和计数的表:
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很快就变得非常混乱了.

解决方法

在这种情况下,您也可以使用 LEAD()功能:
with CTE as
(
select t.*,LEAD(ct) OVER (ORDER BY dt DESC) as LEAD_CT from t
)  
select dt,ct from CTE where LEAD_CT>CT

SQLFiddle demo

UPD:LEAD()可从SQLServer 2012版本获得.在2008年,您可以使用子查询替换它:

select *
      FROM T as T1
      where (SELECT TOP 1 ct FROM T 
                             WHERE T.dt<T1.DT
                             ORDER BY dt DESC) >CT

SQLFiddle demo

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读