昨天,我问了这个问题。我决定改变我的方法并尝试一些新的东西。在开始之前,请先看看我下面的表结构。
我有一个名为People
:
id | name |parent_id
---+------+---------
1 | John | 0
2 | Jane | 1
3 | James| 1
4 | Jack | 0
5 | Jim | 4
6 | Jenny| 4
7 | Mike | 0
所以约翰是简和詹姆斯的父母。树是这样的。
John
-Jane
-James
Jack
-Jim
-Jenny
Mike
问题的不同之处始于迈克。迈克没有父母或孩子。只是一个孤独的人。因此,当我使用以下查询查询我的表时,我在结果集中看不到 Mike
SELECT
t1.name as level1, t2.name as level2
FROM
People as t1
JOIN
People as t2 ON t2.parent_id = t1.id
ORDER BY
level1, level2
如果该查询具有子项,则此查询会将行带到字段 level1。
例子:
level1 | level2
-------+-------
John | Jane
John | James
Jack | Jim
Jack | Jenny
如何在结果中显示 Mike?我应该在查询中更改什么?