MySQL怎么根据当前时间获取连续十二个月统计数据

如果你不相信努力和时光,那么成果就会是第一个选择辜负你的。不要去否定你自己的过去,也不要用你的过去牵扯你现在的努力和对未来的展望。不是因为拥有希望你才去努力,而是去努力了,你才有可能看到希望的光芒。MySQL怎么根据当前时间获取连续十二个月统计数据,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

需求

在某些业务场景中,需要后台获取连续十二个月的统计数据,如下图:
在这里插入图片描述

解决方式

1、创建一张临时表,在表中插入序号数据

该表的最大数量决定统计返回的最大条数

CREATE TABLE `sys_redundancy` (
  `id` bigint(22) NOT NULL AUTO_INCREMENT COMMENT '序号',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1001 DEFAULT CHARSET=utf8 COMMENT='冗余必须表:目前用于用户注册统计,该表的数量决定用户统计返回的条数';

插入连续1000条数据

DROP PROCEDURE IF EXISTS proc_initData;
DELIMITER $
CREATE PROCEDURE proc_initData()
BEGIN
DECLARE i INT DEFAULT 1;
WHILE i<=1000 DO
INSERT INTO sys_redundancy(id) VALUES(i);
SET i = i+1;
END WHILE;
END $
DELIMITER ;

CALL proc_initData();

2、查询SQL

select * from(
SELECT
    IFNULL(count(a.user_id), 0) AS sum,
    b.tdate AS date
FROM
    sys_user a
RIGHT JOIN (
    SELECT
        DATE_FORMAT(DATE_SUB(CURDATE(), INTERVAL n.id-1 MONTH),'%Y-%m') AS tdate
    FROM
        sys_redundancy n 
) b ON DATE_FORMAT(a.create_time,'%Y-%m') = b.tdate and a.user_type = 2 
GROUP BY
    b.tdate
ORDER BY b.tdate desc
limit 12) m 
ORDER BY m.date asc
;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/202797.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!