昨天我问了this的问题。我决定改变我的方法并尝试新的东西。在开始之前,请看下面我的表格结构。Mysql Adjacency List Model,我的查询结果不是我想要的
我有一个命名为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
问题的不同始于迈克。迈克没有父母或小孩。只是寂寞的人。所以,当我询问我的桌子下面的查询,我不能看到麦克在结果
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
该查询带来的行,如果它有子项(S)到外地1级。
例子:
level1 | level2
-------+-------
John | Jane
John | James
Jack | Jim
Jack | Jenny
我怎么能显示出迈克的结果呢?我应该在查询中更改什么?
您是否尝试过将parent_id设置为NULL而不是0?这可能会改变事情。否则,仅仅为了它的乐趣,试试一个RIGHT JOIN代替 – nover
将0值更新为NULL,结果相同。将左改为右,没有任何改变。 – zkanoca
奇怪的是,在MySQL 5.6上将parent_id设置为NULL值我得到了完整的人员列表。 – nover