作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
昨天问过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
关于Mysql邻接表模型,我的查询结果不是我想要的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17874129/
使用登录后,我想吐出用户名。 但是,当我尝试单击登录按钮时, 它给了我力量。 我看着logcat,但是什么也没显示。 这种编码是在说。 它将根据我在登录屏幕中输入的名称来烘烤用户名。 不会有任何密码。
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎是题外话,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或include a min
我是一名优秀的程序员,十分优秀!