昼与夜 2015-06-01 06:49 采纳率: 0%
浏览 13682
已结题

mysql Group by 日期。每个时间点数据都要显示出来,没有数据的则为 0 .

一张表。
数据的主要结构:
id
num
create_time

我现在写的有问题,只能显示有数据的日期。

SELECT DATE_FORMAT(create_time,'%Y-%m-%d') AS day,
(CASE WHEN COUNT(num)='0' THEN 0 ELSE COUNT(num) END) AS counts
FROM infos
WHERE DATE_FORMAT(create_time,'%Y-%m-%d') BETWEEN '2015-05-01' AND '2015-05-30' GROUP BY day

要求:
每个时间点数据都要显示出来,没有数据的则为 0 .

  • 写回答

4条回答 默认 最新

  • bigsnow 2015-06-01 07:19
    关注

    首先不要把format函数放在where里,datetime类型是可以直接用between比较的,应该写成
    select case create_time when null '0' ......
    where create_time is null or create_time BETWEEN '2015-05-01' AND '2015-05-30'

    评论

报告相同问题?

悬赏问题

  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条