带有“默认值”的 SQL GROUP BY

Posted

技术标签:

【中文标题】带有“默认值”的 SQL GROUP BY【英文标题】:SQL GROUP BY with "default values" 【发布时间】:2011-02-17 14:43:58 【问题描述】:

我正在尝试使用 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 |
+--------------+--------------------+

是否有可能实现这种行为?

【问题讨论】:

有不少重复的主题相同,例如***.com/questions/400759/… 【参考方案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)

【讨论】:

【参考方案2】:

您可以为该范围内的有效日期构建一个临时表,然后将其合并到您的查询中 - 这是我可以立即看到的唯一前进方式...

马丁

【讨论】:

以上是关于带有“默认值”的 SQL GROUP BY的主要内容,如果未能解决你的问题,请参考以下文章

在 SQL 语句中使用 Order by 时出现“参数 xxx 没有默认值”错误

mysql设置timpstamp的默认值为 '0000-00-00 00:00:00' 时报错

mysql的sql_mode合理设置

mysql的sql_mode合理设置

mysql的sql_mode合理设置

mysql group by 问题