具有“默认值”的SQL GROUP BY
问题描述:
我试图用GROUP BY
子句创建SELECT
语句,该语句应返回“默认值”。具有“默认值”的SQL 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 |
+--------------+--------------------+
是否有可能实现这一行为呢?
答
你可以建立在范围内的有效日期的临时表,然后将此主题融入您的查询 - 这是关于前,我马上就可以看到的唯一途径...
马丁
答
正如马丁说,最好的解决方案是创建一个包含日期的临时表。
然后是2点的方法:
请与临时表外连接,并做结果
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)
有相同的主题有相当多的重复,例如http://stackoverflow.com/questions/400759/sql-group-by-date-but-get-dates-wo-rec ORDS太 – Unreason 2010-05-10 10:26:00