mayans005 2020-03-09 11:20 采纳率: 0%
浏览 237
已采纳

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日

悬赏问题

  • ¥15 pycharm倒入虚拟环境的时候,显示这个,但是我的虚拟环境已经创建了
  • ¥15 FPGA芯片60进制计数器
  • ¥15 前端js怎么实现word的.doc后缀文件在线预览
  • ¥20 macmin m 4连接iPad
  • ¥15 DBIF_REPO_SQL_ERROR
  • ¥15 根据历年月数据,用Stata预测未来六个月汇率
  • ¥15 DevEco studio开发工具 真机联调找不到手机设备
  • ¥15 请教前后端分离的问题
  • ¥15 下载honeyd时报错 configure: error: you need to instal a more recent version of libdnet
  • ¥15 距离软磁铁一定距离的磁感应强度大小怎么求
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部