gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-28 23:31:58 25 4
gpt4 key购买 nike

我在解析 MySQL 查询的输出以便提供给 Highcharts 时遇到了一些麻烦。最大的问题是我会 hawe 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();
}
?>

对如何解决该问题有什么建议吗?

最佳答案

看起来您多次使用 $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。这样我可以改进我的答案,或者其他方法也可以帮助你。

关于php - 将 MySQL 输出解析为 JSON 提取字段名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37070434/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com