从SQL表中查找不连续性
发布时间:2020-05-24 11:47:21 所属栏目: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 4
|
对我的问题可能有一个非常简单的解决方案,但我正在为它制定一个好的搜索短语.我有一个包含时间戳和计数的表: 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 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 数据库设计 – 使用Integer vs String获
- MySQL中用通用查询日志找出查询次数最多的语句的教程
- mysql 忘记密码的解决方法(linux和windows小结)
- MySql官方手册学习笔记2 MySql的模糊查询和正则表达式
- 数据库 – 如何更改SQL Server Compact Edition表模式中的列
- sql-server – 使用SQL选择单个xml节点
- sql – SELECT *语句中的列顺序 – 保证?
- 实体框架 – 实体框架是否适用于更大的数据库?
- sql-server – 不使用子查询的不同行的计数
- azure-data-factory – U-SQL无法从JSON文件中提取数据
推荐文章
站长推荐
- sql – 如何在查询中使用divide函数?
- sql-server – SQL Server 2008安装错误:Micros
- SQL在数字字段中搜索非整数
- sql-server-2005 – 索引性能BigInt与VarChar
- SQL Server 按日期选择最晚日期与最早日期对应的
- Mongodb 利用mongoshell进行数据类型转换的实现方
- SQL Server 错误602,未能在sysindexes中找到数据
- 数据库 – WordPress:site_id和blog_id之间的区
- sql-server-2008 – 从time数据类型中删除毫秒,还
- sql-server – SQL Server – 如何在Update命令上
热点阅读
