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

时间:2012-04-16 22:31:38

标签: 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

我想要做的是按CreationDate对行进行分组(仅基于当天,最后的时间不应该是一个因素)。然后将项目一起添加以提供项目/日。

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

2012-04-09 - 130 items
2012-04-14 - 114 items

我在MySQL中尝试过Group By,但我不确定我是否正确使用它:

$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>';
}

除了它之外的那种作品只在精确匹配创建日期(向下到第二个)上对它们进行分组,我不知道如何解决这个问题。

1 个答案:

答案 0 :(得分:4)

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

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

虽然有警告:使用DATE函数将忽略CreationDate上的任何索引。如果对CreationDate字段建立索引,则使用DATE函数并对其进行分组将花费更长的时间。