繁体   English   中英

MySQL到JSON-结合两个查询/格式

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM