mysql如何查询所有子节点

avatar
作者
猴君
阅读量:0

在MySQL中,如果你有一个树形结构的表,可以使用递归查询来获取所有子节点。以下是一种常用的方法:

假设你有一个表tree_table,包含了如下数据:

| id   | name     | parent_id | |------|----------|-----------| | 1    | Root     | NULL      | | 2    | Node1    | 1         | | 3    | Node2    | 1         | | 4    | Node3    | 2         | | 5    | Node4    | 2         | | 6    | Node5    | 3         | 

你可以使用如下的SQL语句来查询Node1节点的所有子节点:

WITH RECURSIVE cte AS (   SELECT id, name, parent_id   FROM tree_table   WHERE name = 'Node1'   UNION ALL   SELECT tt.id, tt.name, tt.parent_id   FROM tree_table tt   JOIN cte ON tt.parent_id = cte.id ) SELECT * FROM cte; 

这个查询语句使用了递归的CTE(Common Table Expression)来获取指定节点的所有子节点。在这个例子中,我们查询了Node1节点的所有子节点。你可以根据需要修改查询语句中的条件来查询其他节点的子节点。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!