2013-07-26 88 views
1

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

我怎麼能顯示出邁克的結果呢?我應該在查詢中更改什麼?

+1

您是否嘗試過將parent_id設置爲NULL而不是0?這可能會改變事情。否則,僅僅爲了它的樂趣,試試一個RIGHT JOIN代替 – nover

+0

將0值更新爲NULL,結果相同。將左改爲右,沒有任何改變。 – zkanoca

+0

奇怪的是,在MySQL 5.6上將parent_id設置爲NULL值我得到了完整的人員列表。 – nover

回答

2

Mike沒有孩子,只需將您的查詢添加UNION即可。你也應該使用INNER JOIN代替LEFT JOIN

select * from 
(
    SELECT 
     t1.name as level1, t2.name as level2 
    FROM 
     People as t1 
    JOIN 
     People as t2 ON t2.parent_id = t1.id 
    UNION 
    select t1.Name as level1, '' as level2 
     from People t1 
     where Parent_id=0 
     and not exists(select 1 from People where Parent_id=t1.Id) 

) People 

ORDER BY 
    level1, level2 

SQLFiddle demo

+0

謝謝。這很棒。 +1 – zkanoca

相關問題