繁体   English   中英

将mysql数据库结果插入php中的多维数组

[英]Inserting mysql database results into a multidimensional array in php

您好,我试图建立一个动态导航菜单,类似于wordpress的工作方式,所以我认为我的问题是我的脚本仅从数据库中检索1个值。 我在这里试图完成的工作是获取数据库中的所有菜单数据并将它们存储在多维数组中

我的数据库结构如下所示:

在此处输入图片说明

这是我如何检索数据

global $db;
    $sql = "SELECT * FROM lm_menu";
    $res = $db->prepare($sql);
    $res->execute();
    $result = $res->fetchAll();
    foreach ($result as $opt_h):
              $nav = array(
        array(
            'id' => $opt_h['id'],
            'name' => $opt_h['name'],
            'link' => $opt_h['ref'],
            'parent' => $opt_h['parent']
        )
    );
    endforeach;

这是读取数组的函数

    function GenerateMenu($nav)
{
    $html = '';
    $html = '<ul class="nav navbar-nav">';
    foreach($nav as $page)
    {
        $html .= '<li>';
        $html .= '<a href="' . $page['link'] . '">' . $page['name'] . '</a>';
        $html .= GenerateNavHTML($page['sub']);
        $html .= '</li>';
    }
    $html .='</ul>';
    return $html;
}

我尝试从Google寻找答案,但没有发现我看到SO的文章 ,但是我没有尝试过,因为在那篇文章中它使用了mysql_ *函数,而我使用了PDO函数。 请帮助我这个家伙

问题是每次迭代, $nav = array(被覆盖。

还可以返回$nav = $res->fetchAll(PDO::FETCH_ASSOC); 无需循环和重新分配。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

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