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

需求

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

解决方式

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
;

相关推荐

  1. mysql 当前时间加3工作日

    2024-01-24 22:32:05       63 阅读
  2. springboot获取当前数据库连接

    2024-01-24 22:32:05       35 阅读
  3. mysql根据datetime统计每日数据

    2024-01-24 22:32:05       26 阅读
  4. js获取当前时间

    2024-01-24 22:32:05       60 阅读
  5. Qt - 获取系统当前时间

    2024-01-24 22:32:05       36 阅读
  6. C语言获取当前时间

    2024-01-24 22:32:05       24 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-24 22:32:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-24 22:32:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-24 22:32:05       82 阅读
  4. Python语言-面向对象

    2024-01-24 22:32:05       91 阅读

热门阅读

  1. LightDB - oracle_fdw join下推增强【24.1】

    2024-01-24 22:32:05       50 阅读
  2. oracle 字符集

    2024-01-24 22:32:05       58 阅读
  3. 为什么写进MySQL里的数据顺序乱了?

    2024-01-24 22:32:05       62 阅读
  4. 2765. 最长交替子数组 ( leetcode 01 - 23 每日 )

    2024-01-24 22:32:05       55 阅读
  5. C++从零开始的打怪升级之路(day19)

    2024-01-24 22:32:05       57 阅读
  6. mybatis多字段模糊查询

    2024-01-24 22:32:05       61 阅读
  7. RHEL8安装Oracle 19c软件runInstaller报错

    2024-01-24 22:32:05       63 阅读
  8. kafka安装

    2024-01-24 22:32:05       62 阅读
  9. python scapy抓包获取udp并转发

    2024-01-24 22:32:05       37 阅读