php - 从数据库表创建数组 "tree"

标签 php mysql arrays tree hierarchical-data

我的php函数

function generateMenu($parent, $level, $menu, $utype) {
    global $db;
    $tree = array();
    $stmt = $db->prepare("select id, parent, name FROM navigation WHERE menu=? AND user_type=?") or die($db->error);
    $stmt->bind_param("ii", $menu, $utype) or die($stmt->error);
    $stmt->execute() or die($stmt->error);
    $stmt->store_result();
    $meta = $stmt->result_metadata();
    $stmt->bind_result($id, $parent, $name);
    while ($stmt->fetch()) {
        $arr[$id] = array(
            'name' => $name, 
            'parent' => $parent
        );
        if (!array_key_exists($parent,$arr) and $parent != 0) {
            $arr[$parent][$id] = $id;
        }
    }
    $stmt->close();
}

从数据库表生成以下数组。 [1], [2] ... - 是 li 项目的 ID

Array (
    [1] => Array ( 
        [name] => Parent1
        [parent] => 0
    ) 
    [2] => Array ( 
        [name] => Parent2
        [parent] => 0 
    )
    [3] => Array (
        [name] => Parent3 
        [parent] => 0 
    )
    [4] => Array ( 
        [name] => Child1 of P1
        [parent] => 1
    ) 
    [5] => Array (
        [name] => Child2 of P1
        [parent] => 1
    ) 
)

我想做的就是创建这样的菜单

<ul>
  <li><a href="?page=1">Parent1</a>
    <ul>
      <li><a href="?page=4">Child1 of P1</a></li>
        ...

第二个函数是从这个数组生成菜单。但我知道在将这个数组发送到第二个函数之前,我需要将它转换成多维树数组。我不知道该怎么做。

这是第二个函数

function olLiTree($tree) {
    $out = '<ul>';

    foreach($tree as $key => $value) {
        $out.= '<li>';

        if (is_array($value)) {
            $out.= $key . olLiTree($value);
        } else {
            $out.= $value;
        }

        $out.= '</li>';
    }

    $out.= '</ul>';

    return $out;
}

数据库结构

http://img338.imageshack.us/img338/4669/6df2a8e6c7684c8aaa82ddf.png

最佳答案

函数array_key_exists()需要两个参数,你只传递一个。我想你的意思是:

while(list($id, $parent, $name) = mysql_fetch_assoc($results)) {
    $tree[$id] = array(
        'name' => $name, 
        'children' => array(), 
        'parent' => $parent
    );
    if (!array_key_exists($parent,$tree)) {
        $tree[$parent]['children'][$id] = $id;
    }
}

您更改了答案,所以我认为您的问题不在于 array_keys_exists。无论如何,您可以尝试通过这种方式使用 MaxDB 获取数据:

function generateMenu($parent, $level, $menu, $utype) {
    global $db;
    $tree = array();
    $stmt = $db->prepare("select id, parent, name FROM navigation WHERE menu=? AND user_type=?") or die($db->error);
    $stmt->bind_param("ii", $menu, $utype) or die($stmt->error);
    $stmt->execute() or die($stmt->error);
    $stmt->store_result();
    $meta = $stmt->result_metadata();

    $stmt->bind_result($id, $parent, $name);
    while ($stmt->fetch()) {
        $tree[$id] = array(
            'name' => $name, 
            'children' => array(), 
            'parent' => $parent
        );
        if (!array_key_exists($parent,$tree)) {
            $tree[$parent]['children'][$id] = $id;
        }
    }
    $stmt->close();
    print_r($tree);
}

对于你的第二个功能,我认为@jeroen 在 this anwser 中是正确的正是您所需要的。

关于php - 从数据库表创建数组 "tree",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8220902/

相关文章:

Java,Mysql-列名标识为变量

arrays - 快速比较两个数组的内容

arrays - 如何在Scala中创建和使用多维数组?

c - 动态分配的结构体指针数组

php - 找不到类规范器(在 PHP 5.3.8 中)

php - CodeIgniter 从 Controller 返回数据

php - 依赖下拉列表获取 id 而不是名称

javascript - 如何将当前HTML+PHP页面代码存储为字符串并用其生成PDF文件

php - SQL SELECT DISTINCT 混淆

php - 分离 PHP 页面,循环遍历 MySQL 表,并创建新的 Div