将MySQL输出解析为JSON提取字段名称

时间:2016-05-06 10:47:04

标签: php mysql json highcharts

我在解析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();
}
?>

有关如何解决该问题的任何建议吗?

1 个答案:

答案 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。这样我可以改善我的答案,或者其他也可以帮助你。