大体思路:

MySQL没有类似oracle方便的统计函数,只能靠自己去硬计算:通过时间字段直接增加年份、月份,然后通过left join关联时间字段去计算环比、同比公式即可

原始表结构:

求同比SQL:

  1. -- 按年同比
  2. SELECT t5.*, CASE WHEN t5.last_energy_year IS NULL OR t5.last_energy_year =0 THEN 0.00
  3. ELSE FORMAT(((t5.energy_year - t5.last_energy_year)/t5.last_energy_year)*100,2)
  4. END YoY  -- 同比
  5. FROM (
  6. SELECT t3.*,t4.last_energy_year
  7. FROM
  8. (
  9. SELECT DATE_FORMAT(CONCAT(t1.`tyear`, '-', t1.`tmonth`,'-01'),'%Y-%m-%d') AS YearMonth,t1.tyear,SUM(t1.energy_month) energy_year,t1.linename
  10. FROM(SELECT
  11. t.*,COUNT(DISTINCT t.`tyear`,t.`tmonth`,t.`linename`) c_cot
  12. FROM `ksh_tgyjy_llxgyjydlxx` t
  13. GROUP BY t.`linename`,t.`tyear`,t.`tmonth`,t.`linename`) t1
  14. GROUP BY t1.tyear,t1.`linename`
  15. ) t3
  16. LEFT JOIN
  17. (
  18. SELECT DATE_ADD(DATE_FORMAT(CONCAT(t1.`tyear`, '-', t1.`tmonth`,'-01'),'%Y-%m-%d'),INTERVAL 1 YEAR) AS lastYearMonth,t1.tyear,SUM(t1.energy_month) last_energy_year,t1.linename
  19. FROM(SELECT t.*,COUNT(DISTINCT t.`tyear`,t.`tmonth`,t.`linename`) c_cot
  20. FROM `ksh_tgyjy_llxgyjydlxx` t
  21. GROUP BY t.`linename`,t.`tyear`,t.`tmonth`,t.`linename`) t1
  22. GROUP BY t1.tyear,t1.`linename`
  23. ) t4
  24. ON t3.YearMonth = t4.lastYearMonth
  25. AND t3.linename = t4.linename
  26. ) t5
-- 按年同比

SELECT t5., CASE WHEN t5.last_energy_year IS NULL OR t5.last_energy_year =0 THEN 0.00

                ELSE FORMAT(((t5.energy_year - t5.last_energy_year)/t5.last_energy_year)
100,2)

        END YoY  -- 同比

FROM (

   SELECT t3.,t4.last_energy_year

    FROM

    (

       SELECT DATE_FORMAT(CONCAT(t1.tyear, '-', t1.tmonth,'-01'),'%Y-%m-%d') AS YearMonth,t1.tyear,SUM(t1.energy_month) energy_year,t1.linename

        FROM(SELECT

        t.
,COUNT(DISTINCT t.tyear,t.tmonth,t.linename) c_cot

        FROM ksh_tgyjy_llxgyjydlxx t

        GROUP BY t.linename,t.tyear,t.tmonth,t.linename) t1

        GROUP BY t1.tyear,t1.linename

     ) t3

      LEFT JOIN

    (

      SELECT DATE_ADD(DATE_FORMAT(CONCAT(t1.tyear, '-', t1.tmonth,'-01'),'%Y-%m-%d'),INTERVAL 1 YEAR) AS lastYearMonth,t1.tyear,SUM(t1.energy_month) last_energy_year,t1.linename

        FROM(SELECT t.,COUNT(DISTINCT t.tyear,t.tmonth,t.linename) c_cot

        FROM ksh_tgyjy_llxgyjydlxx t

        GROUP BY t.linename,t.tyear,t.tmonth,t.linename) t1

        GROUP BY t1.tyear,t1.linename

    ) t4

    ON t3.YearMonth = t4.lastYearMonth

    AND t3.linename = t4.linename

) t5

查询结果:

求月环比SQL:

  1. -- 按月同比  
  2.   
  3. SELECT DATE_FORMAT(t5.YearMonth,'%Y-%m') YearMonth,t5.linename,t5.energy_month,   
  4.          CASE WHEN t5.lat_energy_month IS NULL OR t5.lat_energy_month=0 THEN 0.00  
  5.                  ELSE FORMAT(((t5.energy_month - t5.lat_energy_month)/t5.lat_energy_month)100,2)   
  6.         END YoY  
  7. FROM (   
  8.    SELECT t3.,t4.energy_month lat_energy_month  
  9.      FROM   
  10.     (  
  11.       SELECT DATE_FORMAT(CONCAT(t1.tyear, '-', t1.tmonth,'-01'),'%Y-%m-%d') AS YearMonth,t1.  
  12.         FROM(SELECT   
  13.           t.,COUNT(DISTINCT t.tyear,t.tmonth,t.linename) c_cot   
  14.           FROM ksh_tgyjy_llxgyjydlxx t   
  15.           GROUP BY t.linename,t.tyear,t.tmonth,t.linename) t1  
  16.      ) t3   
  17.        LEFT JOIN   
  18.     (  
  19.       SELECT DATE_ADD(DATE_FORMAT(CONCAT(t1.tyear, '-', t1.tmonth,'-01'),'%Y-%m-%d'),INTERVAL 1 YEAR) AS lastYearMonth,t1.   
  20.         FROM(SELECT t.*,COUNT(DISTINCT t.tyear,t.tmonth,t.linename) c_cot   
  21.         FROM ksh_tgyjy_llxgyjydlxx t   
  22.         GROUP BY t.linename,t.tyear,t.tmonth,t.linename) t1  
  23.     ) t4  
  24.     ON t3.YearMonth = t4.lastYearMonth  
  25.     AND t3.linename = t4.linename  
  26. ) t5  
-- 按月同比

SELECT DATE_FORMAT(t5.YearMonth,'%Y-%m') YearMonth,t5.linename,t5.energy_month,

         CASE WHEN t5.lat_energy_month IS NULL OR t5.lat_energy_month=0 THEN 0.00

                 ELSE FORMAT(((t5.energy_month - t5.lat_energy_month)/t5.lat_energy_month)100,2)

        END YoY

FROM (

   SELECT t3.
,t4.energy_month lat_energy_month

     FROM

    (

      SELECT DATE_FORMAT(CONCAT(t1.tyear, '-', t1.tmonth,'-01'),'%Y-%m-%d') AS YearMonth,t1.*

        FROM(SELECT

          t.,COUNT(DISTINCT t.tyear,t.tmonth,t.linename) c_cot

          FROM ksh_tgyjy_llxgyjydlxx t

          GROUP BY t.linename,t.tyear,t.tmonth,t.linename) t1

     ) t3

       LEFT JOIN

    (

      SELECT DATE_ADD(DATE_FORMAT(CONCAT(t1.tyear, '-', t1.tmonth,'-01'),'%Y-%m-%d'),INTERVAL 1 YEAR) AS lastYearMonth,t1.


        FROM(SELECT t.*,COUNT(DISTINCT t.tyear,t.tmonth,t.linename) c_cot

        FROM ksh_tgyjy_llxgyjydlxx t

        GROUP BY t.linename,t.tyear,t.tmonth,t.linename) t1

    ) t4

    ON t3.YearMonth = t4.lastYearMonth

    AND t3.linename = t4.linename

) t5

查询结果:

MySQL统计同比环比SQL的更多相关文章

  1. mysql统计类似SQL语句查询次数

    mysql统计类似SQL语句查询次数 vc-mysql-sniffer 工具抓取的sql分析. 1.先用shell脚本把所有enter符号替换为null,再根据语句前后的字符分隔语句 grep -Ev ...

  2. 如何查找MySQL中查询慢的SQL语句

    如何查找MySQL中查询慢的SQL语句 更多 如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow ...

  3. 如何查找MySQL中查询慢的SQL语句(转载)

    转载自https://www.cnblogs.com/qmfsun/p/4844472.html 如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那 ...

  4. 何在mysql查找效率慢的SQL语句?

    如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow-queries[=file_name]选项启 ...

  5. MySQL基础操作&&常用的SQL技巧&&SQL语句优化

    基础操作     一:MySQL基础操作         1:MySQL表复制             复制表结构 + 复制表数据             create table t3 like t ...

  6. 数据库MySQL经典面试题之SQL语句

    数据库MySQL经典面试题之SQL语句 1.需要数据库表1.学生表Student(SID,Sname,Sage,Ssex) --SID 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学 ...

  7. MySQL统计信息简介

    作者:王小龙@网易乐得DBA 原文地址: http://mp.weixin.qq.com/s/698g5lm9CWqbU0B_p0nLMw MySQL执行SQL会经过SQL解析和查询优化的过程,解析器 ...

  8. Mysql统计每年每个月的数据——详细教程

    Mysql统计每年每个月的数据(前端页面统计图实现) 最终想实现的效果图,在这里就不多废话了,直接上效果图,由于测试数据有几个月是为0的,所以数据图看着会有点怪怪. 接下来是数据库的两个表,这里直接给 ...

  9. MySQL性能优化(四):SQL优化

    原文:MySQL性能优化(四):SQL优化 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/ ...

随机推荐

  1. animation-fill-mode 之 forwards , transition-timing-function的取值 和 transform属性

    animation-fill-mode 有四个值可选,并且允许由逗号分隔多个值. none 不改变默认行为. forwards 当动画完成后,保持最后一个属性值(在最后一个关键帧中定义). backw ...

  2. 前端(jQuery)(5)-- jQuery AJAX异步访问和加载片段

    异步访问 index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  3. 读书笔记--Spring in Action 目录

    1.Spring之旅 1.1 简化java 开发 1.1.1 激发pojo 的潜能 1.1.2 依赖注入1.1.3 应用切面1.1.4 使用模板消除样板式代码1.2 容纳你的bean1.2.1 与应用 ...

  4. IO流3 --- File类的常用方法2 --- 技术搬运工(尚硅谷)

    File类的判断功能 @Test public void test5(){ File file = new File("hello.txt"); //判断是否是文件目录 Syste ...

  5. vagrant简介

    什么是vagrant? 简单理解,就是可以通过Vagrant这个工具管理虚拟机,比如说想创建一个centos环境的虚拟机,不需要安装系统这么麻烦,通过vagrant可以快速创建 官网地址:https: ...

  6. python 产生二项分布图练习

  7. JavaScript-JQ实现自定义滚动条插件1.0

    此滚动条仅支持竖向(Y轴) 一.Css /*这里是让用户鼠标在里面不能选中文字,避免拖动的时候出错*/ body { -moz-user-select: none; /*火狐*/ -webkit-us ...

  8. 洛谷3953 (NOIp2017) 逛公园——记忆化搜索+用栈判0环

    题目:https://www.luogu.org/problemnew/show/P3953 因为K只有50,所以想到用dp[ cr ][ j ]表示在点cr.比最短路多走了 j 的方案数.(看了TJ ...

  9. Node.js的框架-express

    Node.js的框架 express 是第三方的 express const express=require('express'); const app=express(); const PORT=3 ...

  10. 笔记:投机和投资 F4NNIU

    笔记:投机和投资 F4NNIU 投机是零和交易. 投资是正和博弈. 投机看是短期,只关心当下. 投资是看的长期,更关注未来. 投机容易分散注意力. 投资更关心交易外的注意力. 投机像是看运气,运气有好 ...