Mysql邻接列表模型,我的查询结果不是我想要的

Mysql邻接列表模型,我的查询结果不是我想要的,mysql,sql,Mysql,Sql,昨天,我问了一个问题。我决定改变我的方法,尝试一些新的东西。在开始之前,请看下面我的表格结构 我有一个名为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 -

昨天,我问了一个问题。我决定改变我的方法,尝试一些新的东西。在开始之前,请看下面我的表格结构

我有一个名为
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

我怎样才能让迈克看到结果?我应该在我的查询中更改什么?

迈克没有孩子,所以只需在您的查询中添加具有
工会的人即可。您还应该使用
内部联接
而不是
左联接

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

您是否尝试过将父id设置为NULL而不是0?这可能会改变一切。否则,只是为了好玩,尝试右连接,而不是将0值更新为NULL,结果相同。从左到右更改,没有任何更改。奇怪的是,在MySQL 5.6上,父id为空值,我得到了完整的人员列表。@nover你是对的。如果我只写连接而不是左连接,它将显示我显示的表。