【问题标题】:How to get data from database as nested JSON array?如何从数据库中获取数据作为嵌套 JSON 数组?
【发布时间】:2020-04-13 03:09:57
【问题描述】:

我正在尝试使用 PHP/PDO 从 MySQL 中提取数据并将其格式化为嵌套的 JSON 数组。

这是我得到的:

{
    "host1": [
        {
            "vmnic_name": "vmnic0",
            "switch_name": "switch1",
            "port_id": "GigabitEthernet1\/0\/1"
        },
        {
            "vmnic_name": "vmnic1",
            "switch_name": "switch1",
            "port_id": "GigabitEthernet1\/0\/2"
        }
    ],
    "host2": {
        "2": {
            "vmnic_name": "vmnic0",
            "switch_name": "switch1",
            "port_id": "GigabitEthernet1\/0\/3"
        },
        "3": {
            "vmnic_name": "vmnic1",
            "switch_name": "switch1",
            "port_id": "GigabitEthernet1\/0\/4"
        }
    }
}

我想让它说“host_name”:“host1”等,而不仅仅是“host1”。对于第一个主机之后的主机,没有像第一个主机那样的“2”或“3”这样的数字。

这是我的代码:

$arr = array();
$result = $stmt->fetchAll(PDO::FETCH_ASSOC);
foreach ($result as $key => $item) {
    $arr[$item['host_name']][$key] = array(
            'vmnic_name'=>$item['vmnic_name'],
            'switch_name'=>$item['switch_name'],
            'port_id'=>$item['port_id']
    );
}
echo json_encode($arr, JSON_PRETTY_PRINT);

【问题讨论】:

  • 我想让它说“host_name”:“host1”:您能否澄清一下预期的输出需要是什么?目前尚不清楚结构将如何。

标签: php mysql arrays json pdo


【解决方案1】:

如果只选择查询中的那些列,那么就这么简单:

foreach ($result as $item) {
    $arr[$item['host_name']][] = $item;
}

如果出于某种原因您必须选择更多列供以后使用,则只需插入 host_name 并删除 $key 作为索引:

foreach ($result as $item) {
    $arr[$item['host_name']][] = array(
            'host_name'=>$item['host_name'],
            'vmnic_name'=>$item['vmnic_name'],
            'switch_name'=>$item['switch_name'],
            'port_id'=>$item['port_id']
    );
}

【讨论】:

    【解决方案2】:

    这很容易。将其解码为一个数组,然后将其粘贴到另一个数组中。

    $array = json_decode($json, true);
    $x = [];
    $x['host_name'] = $array;
    
    var_dump(json_encode($x, JSON_PRETTY_PRINT));
    

    这会给你:

    string(747) "{ "host_name": { "host1": [ { "vmnic_name": "vmnic0", "switch_name": "switch1", "port_id": "GigabitEthernet1\/0\/1" }, { "vmnic_name": "vmnic1", "switch_name": "switch1", "port_id": "GigabitEthernet1\/0\/2" } ], "host2": { "2": { "vmnic_name": "vmnic0", "switch_name": "switch1", "port_id": "GigabitEthernet1\/0\/3" }, "3": { "vmnic_name": "vmnic1", "switch_name": "switch1", "port_id": "GigabitEthernet1\/0\/4" } } } }"
    

    https://3v4l.org/PlbON

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-02-04
      • 2021-10-20
      • 1970-01-01
      • 2019-09-16
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多