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 = 0

WHILE(@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
            END

SELECT @R_C = @State_Count,@R_S = @RS
         --SELECT @State_Count AS Times, @RS AS Count
    END
END

执行结果

从1万多条记录中,统计耗时12秒左右.

虽然可以统计出来,但在统计数据较多时,等待的时间可想而知,有没有方法将其优化一下呢?

MSSQL 查询统计某状态出现的次数及累计时间的更多相关文章

  1. MSSQL·查询T-SQL语句执行时间的三种方法

    阅文时长 | 0.23分钟 字数统计 | 420.8字符 主要内容 | 1.引言&背景 2.自定义时间变量求差法 3.MSSQL内置方法 4.MSSQL选项开启时间统计 5.声明与参考资料 『 ...

  2. mysql操作命令梳理(5)-执行sql语句查询即mysql状态说明

    在日常mysql运维中,经常要查询当前mysql下正在执行的sql语句及其他在跑的mysql相关线程,这就用到mysql processlist这个命令了.mysql> show process ...

  3. MSSQL·查询数据库中所有索引的相关信息

    阅文时长 | 0.45分钟 字数统计 | 784字符 主要内容 | 1.引言&背景 2.声明与参考资料 『MSSQL·查询数据库中所有索引的相关信息』 编写人 | SCscHero 编写时间 ...

  4. MSSQL·查询存储过程中的关键字

    阅文时长 | 0.22分钟 字数统计 | 408字符 主要内容 | 1.引言&背景 2.声明与参考资料 『MSSQL·查询存储过程中的关键字』 编写人 | SCscHero 编写时间 | 20 ...

  5. SQL Server2016 新功能实时查询统计信息

    SQL Server2016 新功能实时查询统计信息 很多时候有这样的场景,开发抱怨DBA没有调优好数据库,DBA抱怨开发写的程序代码差,因此,DBA和开发都成为了死对头,无法真正排查问题. DBA只 ...

  6. Linux 统计某个字符串出现的次数

    要统计一个字符串出现的次数,这里现提供自己常用两种方法: 1. 使用vim统计 用vim打开目标文件,在命令模式下,输入 :%s/objStr//gn 即可 2. 使用grep: grep -o ob ...

  7. ORACLE查询当前资产状态,和另一个数据库联查,(查询重复数据中第一条),子查询作为字段查询

    背景:ORACLE查询当前资产状态,包含资产信息(表1),资产维修状态(表2),资产报废状态(表3) 如下: 资产信息:

  8. Java利用正则表达式统计某个字符串出现的次数

    //统计某个字符出现的次数 private void countSubString(){ String string1="香蕉.玉米.面粉"; String string2=&qu ...

  9. EXCEL中统计单元格内容出现次数

    参考网站: https://jingyan.baidu.com/article/7c6fb428dfcc9580642c90ae.html 统计单元格内容出现次数是工作中经常会涉及到的问题. 那么,如 ...

随机推荐

  1. display 属性

    这里向大家描述一下HTML DOM display属性的定义和用法,HTML DOM display属性主要用来设置元素如何显示,比如当此属性值为none时,表示此元素不会被显示,而block则表示此 ...

  2. C语言结构体占用空间内存大小解析

    结构体的数据类型的有点我们就不啰嗦了,直接来看相同数据结构体的几种书写的格式吧. 格式一: 01.struct tagPhone 02.{ 03.     char   A; 04.     int  ...

  3. Oracle中批量插入

    为了防止OracleConnection的重复打开和关闭,使用begin end:将sql语句包在里面,然后一次性执行提高插入的效率. 下面代码中要插入的数据在list集合中,如果list集合的cou ...

  4. IIS6中ASP.NET实现对静态文件的授权控制

    后台使用html+ashx+js开发 在VS2008调试并未发现问题 发布到IIS6才发现不需要验证也能访问html文件 解决这个问题配置IIS即可了 方法如下: IIS配置:网站->属性-&g ...

  5. RAID磁盘阵列0、1、5、10

    raid0:(又称为Stripe或Striping--分条) (一句话:raid0 用多个磁盘串联起来成一个大磁盘,容量为几个的总和.优点:容量大,速度快.缺点:数据不安全) 即Data Stripp ...

  6. spring注解机制和XML配置机制之间的比较

    XML配置的优缺点: 优点有:1. XML配置方式进一步降低了耦合,使得应用更加容易扩展,即使对配置文件进一步修改也不需要工程进行修改和重新编译.2. 在处理大的业务量的时候,用XML配置应该更加好一 ...

  7. Autoit实现分割字符串,循环输出元素

    #include <MsgBoxConstants.au3> Local $aDays = StringSplit("Mon,Tues,Wed,Thur,Fri,Sat,Sun& ...

  8. Oracle归档日志定时删除任务

    1.在Oracle账号下,创建归档日志删除文件del_arch.sh 文件位置:/home/oracle/crontabOra,内容如下: #!/bin/bash LOG_DIR=/home/orac ...

  9. 绑定dropdownlist

    System.Data.SqlClient.SqlConnection sqlconn = new System.Data.SqlClient.SqlConnection(); sqlconn.C; ...

  10. 转:Zend Framework 2.0 分析

    文章来自于:http://bbs.phpchina.com/thread-268362-1-1.html ZF2已经发布,与ZF1相比,MVC这一模块内部的实现机制可谓大相径庭,许多用过ZF1的PHP ...