tree形结构的Nested Set 数据如何转成Adjacency List的

小弟遇到一个难题,需要对一个项目二次开发,但是这个项目有一张分类表(types)的数据结构是按照Nested Set方式来保存的,为了适应本公司的这套,需要转成毗邻目录Adjacency List的模式,大神们可有代码提供借鉴?

阅读 3.5k
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 就可以得到类似邻接表的形态。

推荐问题
宣传栏