我正在尝试使用SELECT
子句创建GROUP BY
语句,该子句应返回“默认值”。
想象一下以下简单的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 |
+--------------+--------------------+
是否有可能实现这种行为?
答案 0 :(得分:3)
您可以在范围内构建一个有效日期的临时表,然后将其合并到您的查询中 - 这是我可以立即看到的唯一前进方式......
马丁
答案 1 :(得分:1)
正如Martin所说,最好的解决方案是创建一个带日期的临时表。
然后有两种方法:
对该临时表执行外连接并对结果执行group by
,或
group by
+ UNION select date,0 as count from date_table d where not exists (select 1 from customer c where c.date=d.date)