我在解析MySQL查询的输出时遇到麻烦,以便为Highcharts提供信息。最大的问题是我会有100多个数据系列,我想在解析过程中不要引用每个列名,现在所需的输出就是这样:
[
{'name':'TS','data':[4349,4375]}
{'name':'time1','data':[503,573]}
{'name':'time2','data':[500,506]}
{'name':'time3','data':[508,649]}
]
但是我坚持使用这个输出,其中所有数据都打印在唯一的第一个数组中:
[
{'name':'TS','data':[4349,503,573,500,4375,506,508,649,]}
{'name':'time1','data':[]}
{'name':'time2','data':[]}
{'name':'time3','data':[]}
]
我使用的PHP代码如下:
<?php
try {
$con= new PDO('mysql:host=localhost;dbname=test', "root", "");
$con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$query = "SELECT TIME_TO_SEC(TS) as TS, TIME_TO_SEC(time1) as time1, TIME_TO_SEC(time2) as time2, TIME_TO_SEC(time3) as time3 FROM time ORDER BY TS";
//first pass just gets the column names
print "[";
$result = $con->query($query);
//return only the first row (we only need field names)
$row = $result->fetch(PDO::FETCH_ASSOC);
//second query gets the data
$data = $con->query($query);
$data->setFetchMode(PDO::FETCH_ASSOC);
foreach ($row as $field => $value){
print "{'name':'$field','data':[";
foreach($data as $row){
foreach ($row as $name=>$value){
print " $value,";
}
}
print "]}";
}
print "]";
}
catch(PDOException $e) {
echo 'ERROR: ' . $e->getMessage();
}
?>
有关如何解决该问题的任何建议吗?
答案 0 :(得分:1)
您似乎多次使用$row
导致循环创建错误。
将内部$row
变量重命名为其他内容,例如$innerData
。
foreach ($row as $field => $value){
print "{'name':'$field','data':[";
foreach($data as $innerData){
foreach ($innerData as $name=>$innerValue){
print " $innerValue,";
}
}
print "]}";
}
但是代码中似乎存在更多问题。 您使用$ query查询数据库2次。你会得到2个相同的结果集。您是否错过了插入第二个查询语句?
请包含查询将在mysql中生成的结果,而不包含php。这样我可以改善我的答案,或者其他也可以帮助你。