MSSQL 查询统计某状态出现的次数及累计时间
1、问题来源
最近客户需要统计某个设备,某状态,在某一个时间段内出现的次数,并计算累计出现的时间。
数据源如下:
现在如果要统计UPSCTSTA状态为D出现的次数(同一状态,连续出现的认为是一次),并计算累计出现的时间
解决方法
方案1,采用存储过程
CREATE PROCEDURE [dbo].[Proc_UPSState_Statistics]
@Guid VARCHAR(32),
@State VARCHAR(2),
@STime DATETIME,
@ETime DATETIME,
@R_C INT OUTPUT,
@R_S INT OUTPUT
AS
BEGIN
SET NOCOUNT ON;
SELECT IDENTITY(INT,1,1) AS ID,Guid,UPSCTState,RecordTime INTO #TSTE FROM [dbo].[EUPSDeviceRunRecordLog] WHERE Guid = @Guid AND RecordTime >= @STime AND RecordTime <= @ETime ORDER BY RecordTime
DECLARE @R_Count INT,@RS INT,@State_Count INT --记录总数,累计时长,累计次数
SELECT @RS = 0,@State_Count = 0, @R_S = 0, @R_C = 0 --给统计变量,输出返回值给初始化为0
SELECT @R_Count = COUNT(*) FROM #TSTE
PRINT '符合条件记录:' + STR(@R_Count)
IF(@R_Count < 1) --少于两条记录不预统计
BEGIN
--SELECT @State_Count AS Times,@RS AS Count
PRINT '在指定时间段内未能查询 ' + @Guid + ' 设备的状态 ' + @State + ' 的记录'
END
ELSE BEGIN
DECLARE @I INT --计数器,步长计数器
DECLARE @ST VARCHAR(2) --临时状态
DECLARE @RTime DATETIME,@LTime DATETIME,@DF DATETIME --当前记录的记录时间、最后一次(上条)此状态记录的时间、时间常量
SELECT @DF = '1979-01-01 0:01:01', @LTime = @DF
DECLARE @ST_FLAG INT --符合条件状态记录开始,结果标记,用于统计次数
SELECT @I = 1, @ST_FLAG = 0WHILE(@I <= @R_Count)
BEGIN
SELECT @ST = UPSCTState,@RTime = RecordTime FROM #TSTE WHERE ID = @I
IF(@ST = @State)
IF(@LTime = @DF)
BEGIN
SET @LTime = @RTime
SET @ST_FLAG = 1
END
ELSE
BEGIN
SET @RS = @RS + DATEDIFF(S,@LTime,@RTime)
SET @LTime = @RTime
END
ELSE
BEGIN
SET @LTime = @DF
IF(@ST_FLAG = 1)
BEGIN
SET @State_Count = @State_Count + 1
SET @ST_FLAG = 0
END
END
SET @I = @I + 1
ENDSELECT @R_C = @State_Count,@R_S = @RS
--SELECT @State_Count AS Times, @RS AS Count
END
END执行结果
从1万多条记录中,统计耗时12秒左右.
虽然可以统计出来,但在统计数据较多时,等待的时间可想而知,有没有方法将其优化一下呢?
MSSQL 查询统计某状态出现的次数及累计时间的更多相关文章
- MSSQL·查询T-SQL语句执行时间的三种方法
阅文时长 | 0.23分钟 字数统计 | 420.8字符 主要内容 | 1.引言&背景 2.自定义时间变量求差法 3.MSSQL内置方法 4.MSSQL选项开启时间统计 5.声明与参考资料 『 ...
- mysql操作命令梳理(5)-执行sql语句查询即mysql状态说明
在日常mysql运维中,经常要查询当前mysql下正在执行的sql语句及其他在跑的mysql相关线程,这就用到mysql processlist这个命令了.mysql> show process ...
- MSSQL·查询数据库中所有索引的相关信息
阅文时长 | 0.45分钟 字数统计 | 784字符 主要内容 | 1.引言&背景 2.声明与参考资料 『MSSQL·查询数据库中所有索引的相关信息』 编写人 | SCscHero 编写时间 ...
- MSSQL·查询存储过程中的关键字
阅文时长 | 0.22分钟 字数统计 | 408字符 主要内容 | 1.引言&背景 2.声明与参考资料 『MSSQL·查询存储过程中的关键字』 编写人 | SCscHero 编写时间 | 20 ...
- SQL Server2016 新功能实时查询统计信息
SQL Server2016 新功能实时查询统计信息 很多时候有这样的场景,开发抱怨DBA没有调优好数据库,DBA抱怨开发写的程序代码差,因此,DBA和开发都成为了死对头,无法真正排查问题. DBA只 ...
- Linux 统计某个字符串出现的次数
要统计一个字符串出现的次数,这里现提供自己常用两种方法: 1. 使用vim统计 用vim打开目标文件,在命令模式下,输入 :%s/objStr//gn 即可 2. 使用grep: grep -o ob ...
- ORACLE查询当前资产状态,和另一个数据库联查,(查询重复数据中第一条),子查询作为字段查询
背景:ORACLE查询当前资产状态,包含资产信息(表1),资产维修状态(表2),资产报废状态(表3) 如下: 资产信息:
- Java利用正则表达式统计某个字符串出现的次数
//统计某个字符出现的次数 private void countSubString(){ String string1="香蕉.玉米.面粉"; String string2=&qu ...
- EXCEL中统计单元格内容出现次数
参考网站: https://jingyan.baidu.com/article/7c6fb428dfcc9580642c90ae.html 统计单元格内容出现次数是工作中经常会涉及到的问题. 那么,如 ...
随机推荐
- HTML&CSS基础学习笔记1.30-颜色的表达
颜色的表述 在网页中的颜色设置是非常重要,CSS的属性有字体颜色(color).背景颜色(background-color).边框颜色(border)等,设置颜色的方法也有很多种: 1.英文命令颜色 ...
- SQL主、外键,子查询
主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个 ...
- es6整理
1.const和let let类似于var,不同的是let只在所在的代码段有效 for循环的计数器,就很合适使用let命令. let和var的区别: //变量i是var声明的,在全局范围内都有效.所以 ...
- windows10 预览版 中英文官方下载地址+激活密钥+网盘分享
windows10 预览版 中英文官方下载地址+激活密钥+网盘分享 产品密钥:NKJFK-GPHP7-G8C3J-P6JXR-HQRJR 英语 64 位 (x64) http://iso.esd.m ...
- 「30天自制操作系统」 Stop & 「OS67 」 Start
废话 整个十月都没有再写一点什么, 其实没什么好写的, 把书里的东西码出来贴在博客里实在没什么意思, 况且书里已经写得够详细了. 这本书给我最深刻的感觉是, 作者通过简化一些细节, 一步一步地模拟整个 ...
- php通过curl实现bigpipe
BigPipe是facebook发明的一种页面加载技术.其实也不是什么新技术了,也有很多文章进行说明.但是在网上,具体讲如何使用php实现bigpipe的文章很少,并且有些文章还不很准确.bigpip ...
- 嵌入式 现已发展为 IT行业的主流——高薪,且人才缺乏
嵌入式 现已发展为 IT行业的主流——高薪,且人才缺乏 硅谷芯微技术中心,注重实践操作,以实际项目带学员,让学员真正学到东西,达到企业用人标准,有兴趣的,可以前来了解,给自己多一个选择的机会,可以多家 ...
- EntityFramework 插件之EntityFramework.Extended (批量处理)
接手了一个用EF来做的项目,由于项目中使用的原生处理,导致很多update都是采用先select 后 update的方式来实现,同时无法批量执行逻辑如:根据订单类型统一更新状态等.所以在经过了N多查找 ...
- Local System、Local Service與Network Service
CreateService参数介绍SC_HANDLE CreateService( SC_HANDLE hSCManager, //服务控制管理程序维护的登记数据库的句柄,由系统函数OpenSCMan ...
- 【HDOJ】1314 Numerically Speaking
学了几天的Java了,终于独立A了一道大数计算.感觉还得练Java啊. import java.util.Scanner; import java.math.BigInteger; import ja ...