我有一个看起来像这样的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>';
}
除了它之外的那种作品只在精确匹配创建日期(向下到第二个)上对它们进行分组,我不知道如何解决这个问题。
答案 0 :(得分:4)
您需要为CreationDate字段使用日期函数,例如:
SELECT SUM(Items), DATE(CreationDate) FROM People GROUP BY DATE(CreationDate) ORDER BY CreationDate DESC
虽然有警告:使用DATE函数将忽略CreationDate上的任何索引。如果对CreationDate字段建立索引,则使用DATE函数并对其进行分组将花费更长的时间。