首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >获取MySQL/MariaDB关系表中给定父节点的所有子节点(及其子节点)

获取MySQL/MariaDB关系表中给定父节点的所有子节点(及其子节点)
EN

Stack Overflow用户
提问于 2016-12-13 04:38:41
回答 1查看 2.5K关注 0票数 1

我有一张这样的桌子:

代码语言:javascript
运行
复制
parent, child
0 2
0 8
2 3
2 6
3 4
3 5
6 7
6 9
9 10

我正在寻找一个查询来选择给定父级的子树,也就是说,如果给定的父级是"6",则输出必须是:{10,9,7,6}

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-13 05:17:16

切克这个。在@pv := '6‘中指定的值应该设置为要查找它的所有后代的父父的id。

此外,您还可以查看实时演示更新

代码语言:javascript
运行
复制
            select  Parent, concat ( "{" ,Parent,",",GROUP_CONCAT(concat (child )SEPARATOR ','),"}")   as Child
            from    (select * from #TableName
                     order by parent, child) s,
                    (select @pv := '6') initialisation
            where   find_in_set(parent, @pv) > 0
            and     @pv := concat(@pv, ',', child);

产出:{6,7,9,10}

要将带有父列的子类显示为一列,请使用以下查询:

代码语言:javascript
运行
复制
            select parent as child from tchilds where parent = @pv2
            union
            select  Child
            from    (select * from tchilds
                     order by parent, child) s,
                    (select @pv2 := '6') initialisation
            where   find_in_set(parent, @pv2) > 0
            and     @pv2 := concat(@pv2,',', child)

输出

如果您还有任何问题或关切,请告诉我们。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41113828

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档