在PHP/MySQL中将值分组,并将其中一列的值添加到组中

在PHP/MySQL中将值分组,并将其中一列的值添加到组中,php,mysql,Php,Mysql,我有一个MySQL数据库,如下所示: Name: Joe Items: 25 CreationDate: 2012-04-14 18:49:50 Name: John Items: 89 CreationDate: 2012-04-14 18:47:17 Name: Bill Items: 95 CreationDate: 2012-04-09 12:34:08 Name: Bob Items: 35 CreationDate: 2012-04-09 12:18:23 我想做的是根据Cr

我有一个MySQL数据库,如下所示:

Name: Joe
Items: 25
CreationDate: 2012-04-14 18:49:50

Name: John
Items: 89
CreationDate: 2012-04-14 18:47:17

Name: Bill
Items: 95
CreationDate: 2012-04-09 12:34:08

Name: Bob
Items: 35
CreationDate: 2012-04-09 12:18:23
我想做的是根据CreationDate只基于一天对行进行分组,最后的时间不应该是一个因素。然后将这些项目加在一起,得出每天的项目数

所以我希望输出是这样的:

2012-04-09 - 130 items
2012-04-14 - 114 items
我在MySQL中尝试过Groupby,但我不确定是否正确使用了它:

$sql = mysql_query("SELECT SUM(Items), CreationDate FROM People GROUP BY CreationDate ORDER BY CreationDate DESC") or die(mysql_error());
while($row = mysql_fetch_array($sql) ) {
    echo '<p>' . $row['CreationDate'] . ' - ' . $row['SUM(Items)'] . '</p>';
}

这类功能有效,但它仅在精确的匹配创建日期(一直到第二天)对它们进行分组,我不确定如何解决这一问题。

您需要对CreationDate字段使用Date函数,例如:

SELECT SUM(Items), DATE(CreationDate) FROM People GROUP BY DATE(CreationDate) ORDER BY CreationDate DESC

不过警告:使用DATE函数将忽略CreationDate上的任何索引。如果CreationDate字段已编制索引,则使用DATE函数并对其进行分组将花费更长的时间。

您需要为CreationDate字段使用DATE函数,例如:

SELECT SUM(Items), DATE(CreationDate) FROM People GROUP BY DATE(CreationDate) ORDER BY CreationDate DESC

不过警告:使用DATE函数将忽略CreationDate上的任何索引。如果CreationDate字段已编制索引,使用DATE函数并对其进行分组将花费更长的时间。

但我如何不考虑结束时的时间?@Talon DATE仅从datetime值中提取日期部分。但我如何不考虑结束时的时间?@Talon DATE仅从datetime值中提取日期部分。仅一点点请注意,您可能希望使用mysqli\u查询而不是mysql\u查询。mysql\u查询是一个旧的API。在这里阅读更多信息:只是一个小提示,您可能希望使用mysqli\u查询而不是mysql\u查询。mysql\u查询是一个旧的API。请在此处阅读更多信息: