[英]MySQL to JSON - Combining Two Queries / Formatting
我正在使用PHP / MySQL运行查询并将其编码为JSON,但是我不确定如何将JSON转换为所需的形式。
这是我的PHP:
$myquery1 = "select 'links' as type, source, target, value from table";
$myquery2 = "select 'nodes' as type, name from table2";
$query = mysql_query($myquery1);
if ( ! $query ) {
echo mysql_error();
die;
}
$data = array();
for ($x = 0; $x < mysql_num_rows($query); $x++) {
$data[] = mysql_fetch_assoc($query);
}
//(and again for myquery2)
echo json_encode($data); //not sure how to combine queries here
我希望按“类型”对JSON进行分组,如下所示:
{
"links": [{"source":"58","target":"john","value":"95"},
{"source":"60","target":"mark","value":"80"}],
"nodes":
[{"name":"john"}, {"name":"mark"}, {"name":"rose"}]
}
任何帮助深表感谢。 谢谢!
你可以做:
$data = array(
"links" => array(),
"nodes" => array()
);
..
// for each link
$data["links"][] = mysql_fetch_assoc($query);
..
// for each node
$data["nodes"][] = mysql_fetch_assoc($query);
我认为mysql_fetch_assoc
将每列添加两次,一次是通过其名称,一次是通过索引,因此您将需要进行一些修整。 即:
$row = mysql_fetch_assoc($query);
$data["links"][] = array(
"name" => $row["name"],
.. etc
)
在for循环条件下执行mysql_num_rows($query)
可能是一个问题。 该值永远不会改变,但是PHP必须在每个循环中运行该函数。 缓存值或使用:
while (($row = mysql_fetch_assoc($res)) !== false) { .. }
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.