我希望你们一切都好。
我目前正在自学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]
如果有人能为我提供有关如何解决此问题的任何指示,那将真正帮助我。
谢谢大家。
与其在服务器上进行平均计算,不如让MySQL为您完成。您可以使用这样的查询直接从MySQL检索分组和平均的数据
SELECT avg(foodScore), visitDateTime FROM feedback WHERE visitDateTime BETWEEN FROM_UNIXTIME($fromDate) AND FROM_UNIXTIME($toDate) group by visitDateTime
如果这不起作用,请告诉我