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

标签 mysql sql

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

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

所以约翰是简和詹姆斯的 parent 。树是这样的。

John
-Jane
-James
Jack
-Jim
-Jenny
Mike

问题的不同从迈克开始。迈克没有 parent 或 child 。只是一个孤独的人。所以当我用下面的查询查询我的表时,我在结果集中看不到 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?我应该在查询中更改什么?

最佳答案

Mike 没有 child ,所以只需将带有 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

关于Mysql邻接表模型,我的查询结果不是我想要的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17874129/

相关文章:

java - 使用 Java 从 MySQL 加载 Highcharts

sql - 删除 SQL Server 中的尾随空格并更新列

mysql - 如何构建多行更新的 SQL 查询

mysql - 在分层表结构中将父节点连接到子节点

php - MySQL 使用 PHP

mysql - 是否可以在两列上使用 mysql group_concat 以在一个列中获得结果?

MySql - 使用同一表的某些字段的值更新表的某些字段

java - 使用 Select Case 进行 JPA 条件查询

mysql - 如何在单行中获取最小值和最大值以及相应的 id

java - 为什么实体没有存储在数据库中?