我刚刚开始使用这个算法,它确实是一个很棒的方法。我唯一坚持的是我怎么能只检索树中的 n 个级别,例如......
Img src = http://www.sitepoint.com/hierarchical-data-database-2/(很棒的文章)
在上图中,我如何选择 Food 的所有子项,但只有 2 层深入到树中(除了樱桃和香蕉之外的所有东西)。
你只需要用伪代码回答,但如果你愿意,你可以用 MySQL。
我当前的 SQL 查询如下所示:
SELECT `treeItems`.`ID` AS `treeItemsID`, `treeItems`.`parent`, `treeItems`.`type`
FROM
`treeItems`,
(
SELECT `lft`, `rgt` FROM `treeItems` WHERE `ID` = $parent
) AS `parentRow`
WHERE `treeItems`.`lft` > `parentRow`.`lft` AND `treeItems`.`lft` < `parentRow`.`rgt`