yyh777
昼与夜
采纳率0%
2015-06-01 06:49 阅读 13.1k

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

1

一张表。
数据的主要结构:
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 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'

    点赞 评论 复制链接分享
  • edouardzyc edouardzyc 2015-06-01 07:28

    你要现有一张从 '2015-05-01' 到 '2015-05-30' 30行记录的主表,然后去left join 你的infos表

    点赞 评论 复制链接分享
  • Gamehu520 Gamehu520 2015-06-03 06:42

    你如果就想用一张表查,就用自链接或者子查询,组合数据,

    点赞 评论 复制链接分享
  • qq_34735535 习惯守望 2016-05-26 08:02

    解决出来没 我现在也遇到了同样类型的问题 必须得一张表 表老大不准加或改

    点赞 评论 复制链接分享

相关推荐