mayans005 2020-03-09 19:20 采纳率: 0%
浏览 235
已采纳

PHP 两级联动数据库生成JSON

图片说明

有上图结构的数据表,欲形成如下格式的JSON数据,PHP代码该如何写?

[
    {
        "name":"电脑",
        "id":"1",
        "list":[
            {
                "name":"无法开机",
                "id":"3"
            },
            {
                "name":"无法联网",
                "id":"4"
            },
            {
                "name":"蓝屏",
                "id":"5"
            }
        ]
    },
    {
        "name":"打印机",
        "id":"2",
        "list":[
            {
                "name":"卡纸",
                "id":"6"
            },
            {
                "name":"加粉",
                "id":"7"
            }
        ]
    }
]
  • 写回答

1条回答 默认 最新

  • 关注
    $sql="select id,name,superior from table where 1=1";
    $requ = mysqli_query($con,$sql);
    $items = array();
    while($rs=mysqli_fetch_array($requ)){
        $a=array("title"=>$rs['name'],"value"=>$rs['id'],"pid"=>$rs['superior']);
        array_push($items,$a);
    }
    
    $generateTree = function ($items, $parentKey = 'pid') {
        $tree = $temp = array();
        foreach ($items as $item) {
            $temp[$item['value']] = $item;
        }
        foreach ($items as $item) {
            if (isset($temp[$item[$parentKey]])) {
                $temp[$item[$parentKey]]['list'][] = &$temp[$item['value']];
            } else {
                $tree[] = &$temp[$item['value']];
            }
            unset($temp[$item['value']][$parentKey]);
        }
        return $tree;
    };
    
    $data = json_encode($generateTree($items));
    echo $data;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已采纳回答 12月8日

悬赏问题

  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因