java - tree形结构的Nested Set 数据如何转成Adjacency List的
伊谢尔伦
伊谢尔伦 2017-04-18 10:43:08
0
1
420
伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回覆(1)
伊谢尔伦

之前想簡單了,需要多一層子查詢,修改如下:

SELECT node.name, parent.id AS pid
FROM `nested` as node
  LEFT OUTER JOIN `nested` AS parent
    ON parent.`left` = (
      SELECT MAX(parents.`left`)
      FROM nested AS parents
      WHERE node.`left` > parents.`left` AND node.`left` < parents.`right`
    )
ORDER BY node.id;

參考我先前翻譯整理的https://segmentfault.com/a/11... 中《取得整棵樹》一節的第二個例子,主要的修改是將(COUNT(parent.name) - 1) AS depth 改成 parent.id 就可以得到類似鄰接表的形態。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!