文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySql如何利用父id递归向下查询子节点

2023-06-29 15:51

关注

这篇文章主要介绍了MySql如何利用父id递归向下查询子节点,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

不用写存储过程,不用建数据库函数,一段sql就可以实现

SELECTID.LEVEL,DATA.* FROM(SELECT@ids AS _ids,( SELECT @ids := GROUP_CONCAT( region_id ) FROM region WHERE FIND_IN_SET(parent_id, @ids ) ) AS cids,@l := @l + 1 AS LEVEL FROMregion,( SELECT @ids := 3, @l := 0 ) b WHERE@ids IS NOT NULL ) ID,region DATA WHEREFIND_IN_SET( DATA.region_id, ID._ids ) ORDER BYLEVEL

MySql如何利用父id递归向下查询子节点

测试

--创建测试环境create table t_test(id int PRIMARY key,parent_id int,name varchar(200))insert t_test VALUES(1,null,"中国");insert t_test VALUES(2,1,"华北");insert t_test VALUES(3,2,"山西省");insert t_test VALUES(4,2,"北京");insert t_test VALUES(5,3,"临汾市");insert t_test VALUES(6,4,"北京市");insert t_test VALUES(7,5,"尧都区");insert t_test VALUES(8,6,"朝阳区");insert t_test VALUES(9,7,"解放西路");insert t_test VALUES(10,8,"朝阳北路");SELECT * FROM t_test;

测试数据展示

MySql如何利用父id递归向下查询子节点

查询 id=1,查询中国下边有哪些地方

SELECTID.LEVEL,DATA.* FROM(SELECT@ids AS _ids,( SELECT @ids := GROUP_CONCAT( id ) FROM t_test WHERE FIND_IN_SET(parent_id, @ids ) ) AS cids,@l := @l + 1 AS LEVEL FROMt_test,( SELECT @ids := 1, @l := 0 ) b WHERE@ids IS NOT NULL ) ID,t_test DATA WHEREFIND_IN_SET( DATA.id, ID._ids ) ORDER BYLEVEL

MySql如何利用父id递归向下查询子节点

id=3,查询山西下边有哪些地方

SELECTID.LEVEL,DATA.* FROM(SELECT@ids AS _ids,( SELECT @ids := GROUP_CONCAT( id ) FROM t_test WHERE FIND_IN_SET(parent_id, @ids ) ) AS cids,@l := @l + 1 AS LEVEL FROMt_test,( SELECT @ids := 3, @l := 0 ) b WHERE@ids IS NOT NULL ) ID,t_test DATA WHEREFIND_IN_SET( DATA.id, ID._ids ) ORDER BYLEVEL

MySql如何利用父id递归向下查询子节点

id=4,查询北京下边有哪些地方

MySql如何利用父id递归向下查询子节点

最后再从 id=2 华北地区往下查询

MySql如何利用父id递归向下查询子节点

感谢你能够认真阅读完这篇文章,希望小编分享的“MySql如何利用父id递归向下查询子节点”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯