J'essaie de générer une structure arborescente à partir d'une table dans une base de données. La table est stockée à plat, avec chaque enregistrement ayant un parent_id ou 0. Le but ultime est d'avoir une boîte de sélection générée, et un tableau de noeuds.Comment puis-je générer une arborescence à partir d'une table dans une base de données?
Le code que j'ai à ce jour est:
function init($table, $parent_id = 0)
{
$sql = "SELECT id, {$this->parent_id_field}, {$this->name_field} FROM $table WHERE {$this->parent_id_field}=$parent_id ORDER BY display_order";
$result = mysql_query($sql);
$this->get_tree($result, 0);
print_r($this->nodes);
print_r($this->select);
exit;
}
function get_tree($query, $depth = 0, $parent_obj = null)
{
while($row = mysql_fetch_object($query))
{
/* Get node */
$this->nodes[$row->parent_category_id][$row->id] = $row;
/* Get select item */
$text = "";
if($row->parent_category_id != 0) {
$text .= " ";
}
$text .= "$row->name";
$this->select[$row->id] = $text;
echo "$depth $text\n";
$sql = "SELECT id, parent_category_id, name FROM product_categories WHERE parent_category_id=".$row->id." ORDER BY display_order";
$nextQuery = mysql_query($sql);
$rows = mysql_num_rows($nextQuery);
if($rows > 0) {
$this->get_tree($nextQuery, ++$depth, $row);
}
}
}
Il est presque travail, mais pas tout à fait. Quelqu'un peut-il m'aider à le finir?
ce que vous entendez par presque travailler? Qu'est-ce qui marche, qu'est-ce qui ne fonctionne pas? – markus
Comment poser des questions de manière intelligente: http://www.catb.org/~esr/faqs/smart-questions.html – mozboz