微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

带有“默认值”的SQL GROUP BY

我正在尝试使用GROUP BY子句创建SELECT语句,该子句应返回“认值”.

想象一下以下简单的MySQL表:

CREATE TABLE `tracker` (
  `id` INTEGER PRIMARY KEY auto_increment,`date` DATETIME NOT NULL,`customer_id` INTEGER NOT NULL
);

该表只包含一条记录:

INSERT INTO `tracker` (`date`,`customer_id`) VALUES('2010-05-03',1);

在病房之后,我正在执行以下SQL查询

SELECT DATE(`date`),COUNT(customer_id) FROM tracker
WHERE DATE(`date`) >= '2010-05-01' AND DATE(`date`) <= '2010-05-05'
GROUP BY DATE(`date`) ORDER BY DATE(`date`);

并获得预期的结果集:

+----+---------------------+-------------+
| id | date                | customer_id |
+----+---------------------+-------------+
|  1 | 2010-05-10 00:00:00 |           1 |
+----+---------------------+-------------+

但是,我希望结果集看起来像这样:

+--------------+--------------------+
| DATE(`date`) | COUNT(customer_id) |
+--------------+--------------------+
| 2010-05-01   |                  0 |
| 2010-05-02   |                  0 |
| 2010-05-03   |                  1 |
| 2010-05-04   |                  0 |
| 2010-05-05   |                  0 |
+--------------+--------------------+

有可能实现这种行为吗?

最佳答案
您可以在范围内构建一个有效日期的临时表,然后将其合并到您的查询中 – 这是我能立即看到的唯一前进方式……

马丁

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


mysql外键怎么用?Mysql数据库外键的使用介绍(图文+视频)
mysql怎么创建视图?(图文+视频)
怎么修改Mysql数据表中的视图
phpMyadmin导出备份数据库文件的步骤详解(附视频)
怎么给Mysql数据表添加外键?(图文+视频)
phpMyadmin导入数据库sql文件的方法详解(附视频)
如何查询mysql数据表中的视图
Mysql怎么删除外键?(图文+视频)
mysql数据表视图是什么意思?有哪些用处?(图文+视频)
mysql数据库怎么创建外键?(图文+视频)