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条,否则计算出的数据会缺少

相关推荐
晚霞的不甘9 分钟前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位28 分钟前
JAVA开发常见安全问题:纵向越权
java·数据库·安全
海奥华231 分钟前
mysql索引
数据库·mysql
2601_949593651 小时前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
javachen__1 小时前
mysql新老项目版本选择
数据库·mysql
Dxy12393102162 小时前
MySQL如何高效查询表数据量:从基础到进阶的优化指南
数据库·mysql
Dying.Light2 小时前
MySQL相关问题
数据库·mysql
蜡笔小炘2 小时前
LVS -- 利用防火墙标签(FireWall Mark)解决轮询错误
服务器·数据库·lvs
韩立学长2 小时前
基于Springboot泉州旅游攻略平台d5h5zz02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·旅游
Re.不晚3 小时前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构