6

I'm trying to create SELECT statement with a GROUP BY clause, which should return "default values".

Imagine the following simple MySQL table:

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

The table contains only one record:

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

After wards I'm executing the following SQL query:

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`);

And get the expected result set:

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

However, I would like the result set to look like this:

+--------------+--------------------+
| 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 |
+--------------+--------------------+

Is it possible to achieve this behavior?

4

2 回答 2

3

You could build a temporary table of the valid dates in the range and then incorporate that into your query - that's about the only way forward that I can immediately see...

Martin

于 2010-05-10T10:19:35.270 回答
2

正如马丁所说,最好的解决方案是创建一个带有日期的临时表。

然后有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)

于 2010-05-10T10:43:52.817 回答