PHP - 对匹配变量进行分组并计算平均值

时间:2012-04-24 10:55:36

标签: php jquery graph charts jqplot

我希望你们一切顺利。

我目前正在自学PHP,作为其中的一部分,我一直在尝试开发一个反馈系统,将信息存储在我工作的餐厅的客户反馈卡中。

我的问题围绕着我用来生成json输出的php代码,然后由jqplot用来创建图形。

以下是我用来执行此操作的代码:

<?php

// $toDate and $fromDate will eventually be values coming over via post however i am using static values at the moment for testing

$toDate = time();
$fromDate = time() - (7 * 24 * 60 * 60);

$sql = "SELECT * FROM feedback WHERE visitDateTime BETWEEN FROM_UNIXTIME($fromDate) AND FROM_UNIXTIME($toDate)";

$result = mysql_query($sql) or die(mysql_error());
?>

获取数据后,我在javascript和php中使用此代码生成jqplot数据。

<script>
$(document).ready(function(){
 var line1 = [
<?php
while ($row = mysql_fetch_assoc($result)){
echo '[';
echo "'";
echo $row['visitDateTime'];
echo "',";
echo $row ['foodScore'];
echo ']';
echo ',';
}

?>

];

// code then goes on to generate the chart, etc....

</script>

这样可以正常工作并生成以下json输出:

 var line1 = [
['2012-04-20 19:00:00',7],['2012-04-20 19:00:00',8],['2012-04-20 12:00:00',8],['2012-04-22 16:00:00',5],['2012-04-21 20:00:00',9],  

];

然而,我遇到的问题是,当2个日期和时间相同时(可能是它们),这会导致图表出现问题,因为我有1个日期的多个值。

在给出一些想法之后,我得出的结论是,我需要实际做的是计算日期和时间的平均分数,以便生成如下所示的输出:

var line1 = ['unique date/time', average of all scores from this date/time ]

但我不知道如何开始这样做。

我知道这可能是错的,但我认为我需要遍历所有检索到的记录并检查日期/时间是否相同。所以基本上,而不是返回这个:

['2012-04-20 19:00:00',7],['2012-04-20 19:00:00',8],['2012-04-20 12:00:00',8],['2012-04-20 12:00:00',5],['2012-04-20 12:00:00',9]

我需要回复:

['2012-04-20 19:00:00',7.5],['2012-04-20 12:00:00',7.3]

如果有人能给我任何关于如何解决这个问题的指示,那真的会帮助我。

谢谢大家。

1 个答案:

答案 0 :(得分:2)

您可以让MySQL为您完成,而不是在服务器上进行平均计算。您可以使用这样的查询来检索直接从MySQL

分组和平均的数据
SELECT avg(foodScore), visitDateTime FROM feedback WHERE visitDateTime BETWEEN FROM_UNIXTIME($fromDate) AND FROM_UNIXTIME($toDate) group by visitDateTime

如果这不起作用,请告诉我