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

相关推荐
iAm_Ike2 分钟前
怎么关闭MongoDB不需要的HTTP管理接口及REST API
jvm·数据库·python
whn19779 分钟前
虚拟机搭建oracle 19c rac 点滴
数据库·oracle
m0_7411733313 分钟前
CSS移动端实现卡片悬浮投影_利用box-shadow设置层次感
jvm·数据库·python
Lyyaoo.13 分钟前
Session粘滞性问题->Redis实现session共享
数据库·redis·缓存
珠海西格电力15 分钟前
零碳园区管理系统“云-边-端”架构协同的价值及具体案例
大数据·数据库·人工智能·架构·能源
sinat_3834373616 分钟前
如何在 Laravel 中筛选并格式化匹配预定义列表的产品数据
jvm·数据库·python
2401_8463395617 分钟前
mysql如何用执行流程思维写好SQL_SQL优化方法总结
jvm·数据库·python
鸽芷咕18 分钟前
KingbaseES数据库设计规范与SQL开发最佳实践
数据库·sql·设计规范
forEverPlume21 分钟前
SQL如何统计分组内不重复值的数量_COUNT与DISTINCT结合应用
jvm·数据库·python
极创信息23 分钟前
信创领域五种主流CPU架构(X86 / ARM / RISC-V / MIPS / LoongArch)
java·arm开发·数据库·spring boot·mysql·软件工程·risc-v