每小时电量的计算sql

计算思路,把每小时的电表最大记录取出来,然后用当前小时的最大值减去上个小时的最大值即可。 使用了MYSQL8窗口函数进行计算。

sql 复制代码
SELECT b.*,b.epimp - b.lastEmimp ecValue  FROM (
SELECT a.deviceId,a.ctime,a.epimp, lag(epimp) over (ORDER BY a.deviceId,a.ctime) AS lastEmimp
FROM (SELECT
        deviceId,
        DATE_FORMAT(CTIME, '%Y-%m-%d %H') ctime,
        MAX(EP_IMP)    epimp
      FROM electricity
      WHERE deviceId IN('AAA1','AAAA2')
          AND ctime > '2024-05-01'
      GROUP BY deviceId, DATE_FORMAT(CTIME, '%Y-%m-%d %H')) a
      )b 

经过AI优化后的sql

sql 复制代码
WITH a AS (
    SELECT deviceId,
           DATE_FORMAT(CTIME, '%Y-%m-%d %H') ctime,
           MAX(EP_IMP)    epimp
    FROM electricity
    WHERE deviceId IN('1001','1002')
          AND ctime > '2024-05-01'
    GROUP BY deviceId, DATE_FORMAT(CTIME, '%Y-%m-%d %H')
),
b AS (
    SELECT a.deviceId,
           a.ctime,
           a.epimp,
           LAG(a.epimp) OVER (ORDER BY a.deviceId, a.ctime) AS lastEmimp
    FROM a
)
SELECT b.*, b.epimp - b.lastEmimp ecValue
FROM b;
相关推荐
D3bugRealm12 小时前
pgvector:PostgreSQL 原生向量搜索扩展
数据库·其他·postgresql
LPieces12 小时前
【LPieces-UI】01-从零开始搭建 Vue3 组件库
前端
学习使我快乐0112 小时前
AI时代下,前端如何破局
前端·人工智能
Java面试题总结13 小时前
PostgreSQL 性能调优:内存、I/O 与连接管理
数据库·postgresql
北秋,13 小时前
Oracle 数据库基础用法
数据库·oracle
CLX050513 小时前
C#怎么实现全局异常过滤器_C#如何捕获控制器报错【核心】
jvm·数据库·python
yingyima13 小时前
Unix 时间戳转换实战:一次差点毁掉项目的低级错误
前端
多加点辣也没关系13 小时前
设计模式-享元模式
数据库·设计模式·享元模式
牢七13 小时前
Mailvelope
数据库
阿里云瑶池数据库13 小时前
如何破解多租户隔离与性能难题?PolarDB PostgreSQL实战指南
数据库·postgresql