MySQL统计同比环比SQL
MySQL没有类似oracle方便的统计函数,只能靠自己去硬计算:通过时间字段直接增加年份、月份,然后通过left join关联时间字段去计算环比、同比公式即可
原始表结构:
求同比SQL:
- -- 按年同比
- 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
-- 按年同比 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
FROMksh_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
FROMksh_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:
- -- 按月同比
- 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
-- 按月同比 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
FROMksh_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
FROMksh_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的更多相关文章
- mysql统计类似SQL语句查询次数
mysql统计类似SQL语句查询次数 vc-mysql-sniffer 工具抓取的sql分析. 1.先用shell脚本把所有enter符号替换为null,再根据语句前后的字符分隔语句 grep -Ev ...
- 如何查找MySQL中查询慢的SQL语句
如何查找MySQL中查询慢的SQL语句 更多 如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow ...
- 如何查找MySQL中查询慢的SQL语句(转载)
转载自https://www.cnblogs.com/qmfsun/p/4844472.html 如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那 ...
- 何在mysql查找效率慢的SQL语句?
如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow-queries[=file_name]选项启 ...
- MySQL基础操作&&常用的SQL技巧&&SQL语句优化
基础操作 一:MySQL基础操作 1:MySQL表复制 复制表结构 + 复制表数据 create table t3 like t ...
- 数据库MySQL经典面试题之SQL语句
数据库MySQL经典面试题之SQL语句 1.需要数据库表1.学生表Student(SID,Sname,Sage,Ssex) --SID 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学 ...
- MySQL统计信息简介
作者:王小龙@网易乐得DBA 原文地址: http://mp.weixin.qq.com/s/698g5lm9CWqbU0B_p0nLMw MySQL执行SQL会经过SQL解析和查询优化的过程,解析器 ...
- Mysql统计每年每个月的数据——详细教程
Mysql统计每年每个月的数据(前端页面统计图实现) 最终想实现的效果图,在这里就不多废话了,直接上效果图,由于测试数据有几个月是为0的,所以数据图看着会有点怪怪. 接下来是数据库的两个表,这里直接给 ...
- MySQL性能优化(四):SQL优化
原文:MySQL性能优化(四):SQL优化 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/ ...
随机推荐
- PHP搜索优化 sphinx 搭建测试
安装.环境:win7 64位 1.下载sphinx文件包 下载地址:http://sphinxsearch.com/downloads/archive/ 2.解压到D:/sphinx.新建文件夹dat ...
- 配置 CentOS 7 的网络,及重命名网卡名
Centos 安装时应配置网络,如果当时没配置好,则装完系统后, 也可通过修改配置文件并重启网络服务进行配置. 说明:CentOS 7.0默认安装好之后是没有自动开启网络连接的! cd /etc/sy ...
- 备忘 ubuntu ip 及 dns 的坑
以前都用 ubuntu 16.04 现在用 18.04 遇到几个恶心的事,现在解决了,记录下来. 1. 设置 DNS , DNS 设置老是不对,最后发现问题老版本 ubuntu 17.10以下 ...
- django中模型
一.django需要使用数据库,则需要安装对应的驱动,比如mysql,则需要安装mysqlclient驱动: pip install mysqlclient 二.在settings.py文件中配置数据 ...
- PAI-STUDIO通过Tensorflow处理MaxCompute表数据
PAI-STUDIO在支持OSS数据源的基础上,增加了对MaxCompute表的数据支持.用户可以直接使用PAI-STUDIO的Tensorflow组件读写MaxCompute数据,本教程将提供完整数 ...
- LUGOU 3959 宝藏 (noip 2017 day2 T2)
传送门 解题思路 去年noip现在拿来写..思路还是听清楚的,记忆化搜索,f[S]表示现在选了集合S时的最小代价,dis[i]表示达到最优时i这个点的深度.f[S| (1< < i-1) ...
- 从0开始学习 GitHub 系列之「02.加入 GitHub」
转载地址: http://blog.csdn.net/googdev/article/details/52787586 看完昨天的文章「从0开始学习 GitHub 系列之「初识 GitHub」」估计不 ...
- Python判断文件和文件夹是否存在的方法
Python判断文件和文件夹是否存在的方法 这篇文章主要介绍了Python判断文件和文件夹是否存在的方法,本文还讲解了判断是否为文件或者目录的方法.os.path.lexist的作用.FTP中判断文件 ...
- 使用 store 来优化 React 组件
在使用 React 编写组件的时候,我们常常会碰到两个不同的组件之间需要共享状态情况,而通常的做法就是提升状态到父组件.但是这样做会有一个问题,就是尽管只有两个组件需要这个状态,但是因为把状态提到了父 ...
- tomcat配置证书
[size=x-small][size=xx-large][size=medium] 1.利用java 生成一个.keystore文件 进入命令行(假设已经设定了环境变量) 执行 keytool -g ...