昨天我問了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