mysql 30天自动补0

java 复制代码
SELECT DATA.DAY,
  IFNULL(DATA.count, 0) AS cnt,
  day_list.DAY AS DATE
FROM
(
    SELECT
      @DATE := DATE_ADD(@DATE, INTERVAL - 1 DAY) DAY
    FROM
      (SELECT @DATE := DATE_ADD(CURDATE(), INTERVAL 1 DAY) FROM student) days
      LIMIT 30
  ) day_list 
  
  LEFT JOIN (SELECT DATE_FORMAT(birth_day, '%Y-%m-%d') DAY, count(id) count FROM student GROUP BY DAY) DATA 
  
  ON day_list.DAY = DATA.DAY

结果

这部分是从student表中,取出30条数据,并将日期+1赋值给@DATE变量

java 复制代码
(SELECT @DATE := DATE_ADD(CURDATE(), INTERVAL 1 DAY) FROM student) days
      LIMIT 30

这部分是将@DATE日期-1,并赋值给@DATE,下一次继续-1,赋值给@DATE,直到计算 出30天日期

java 复制代码
SELECT
      @DATE := DATE_ADD(@DATE, INTERVAL - 1 DAY) DAY

这部分是统计同一天出生的学生

java 复制代码
SELECT DATE_FORMAT(birth_day, '%Y-%m-%d') DAY, count(id) count FROM student GROUP BY DAY

所以整个整体就能将30天内同一天出生的学生人数统计出来

这个方案有个缺点,要求student表要超过30条,否则计算出的数据会缺少

相关推荐
萧曵 丶几秒前
MySQL InnoDB 实现 MVCC 原理
数据库·mysql·mvcc
ss2732 分钟前
ruoyi 新增每页分页条数
java·数据库·mybatis
万粉变现经纪人15 分钟前
如何解决 pip install mysqlclient 报错 ‘mysql_config’ not found 问题
数据库·python·mysql·pycharm·bug·pandas·pip
lkbhua莱克瓦2426 分钟前
进阶-SQL优化
java·数据库·sql·mysql·oracle
石小千28 分钟前
Myql binlog反向解析成sql
数据库·sql
alonewolf_9935 分钟前
MySQL 8.0 主从复制原理深度剖析与实战全解(异步、半同步、GTID、MGR)
数据库·mysql·adb
八九燕来44 分钟前
django + drf 多表关联场景下的序列化器选型与实现逻辑
数据库·django·sqlite
Mr. Cao code1 小时前
MySQL数据卷实战:持久化存储秘籍
数据库·mysql·docker·容器
小北方城市网1 小时前
微服务架构设计实战指南:从拆分到落地,构建高可用分布式系统
java·运维·数据库·分布式·python·微服务