节点树
需求:写一个查询语句,输出所有节点的编号和节点的类型,并将结果按照节点编号排序。
表 tree,id 是树节点的编号, p_id 是它父节点的 id 。
树中每个节点属于以下三种类型之一:
叶子:如果这个节点没有任何孩子节点。
根:如果这个节点是整棵树的根,即没有父节点。
内部节点:如果这个节点既不是叶子节点也不是根节点。
id | p_id |
---|---|
1 | null |
2 | 1 |
3 | 1 |
4 | 2 |
5 | 2 |
展示效果:
id | Type |
---|---|
1 | Root |
2 | Inner |
3 | Leaf |
4 | Leaf |
5 | Leaf |
解释:
节点 1 是根节点,因为它的父节点是 NULL ,同时它有孩子节点 2 和 3 。
节点 2 是内部节点,因为它有父节点 1 ,也有孩子节点 4 和 5 。
节点 3, 4 和 5 都是叶子节点,因为它们都有父节点同时没有孩子节点。
Create table If Not Exists 30_tree (id int, p_id int);
Truncate table 30_tree;
insert into 30_tree (id, p_id) values (1, null);
insert into 30_tree (id, p_id) values (2, 1);
insert into 30_tree (id, p_id) values (3, 1);
insert into 30_tree (id, p_id) values (4, 2);
insert into 30_tree (id, p_id) values (5, 2);
最终sql:
-- 连续判断,找到其规律
SELECT
t1.id,
IF(ISNULL(t1.p_id),'Root', IF(t1.id IN (SELECT p_id FROM 30_tree), 'Inner','Leaf')) Type
FROM
30_tree t1
ORDER BY t1.id;