我有下面这张桌子。
+-------+--------+-------+
| Id| Name| Parent|
+-------+--------+-------+
| 0| A| -1|
| 1| B| 0|
| 2| C| 1|
| 3| D| 2|
| 4| E| 2|
| 5| F| 2|
| 6| G| 2|
| 7| H| 2|
| 8| I| 2|
+-------+--------+-------+作为父对象的-1表示它没有父对象。层次结构可以达到7-8个级别。我需要得到所有的孩子(直接+间接)。我试过这样的方法:
SELECT Id, NAME, @pv:=Id AS 'Parent' FROM tbl
JOIN
(SELECT @pv:=-1)tmp
WHERE Parent=@pv但它不起作用。
发布于 2016-07-08 22:22:20
尝试此查询
SELECT t1.name AS lev1, t2.name as lev2
FROM tbl1 AS t1
LEFT JOIN tbl1 AS t2 ON t2.parent = t1.id
WHERE t1.id = 2;预期输出
+-------+--------+
| lev1| lev2|
+-------+--------+
| C| D|
| C| E|
| C| F|
| C| G|
| C| H|
| C| I|
+-------+--------+https://stackoverflow.com/questions/26922620
复制相似问题