根据父ID查询相应的下级
通过父ID查询下级ID很常见,本人遇到后做一个记录
1,第一种方法是只能查询到该ID的下一级,不包含父ID,而且只能查询到一级
SELECT id FROM ( SELECT t1.*, IF(FIND_IN_SET(parent_id, @pids) > 0, @pids := CONCAT(@pids, ',', id), 0) AS ischild FROM ( SELECT * FROM sys_depart t WHERE t.status = '1' and t.del_flag='0' ORDER BY parent_id, id ) t1 , (SELECT @pids := #{pId}) t2 ) t3 WHERE t3.ischild != 0
2,第二种方法采用递归方法,先写一个递归函数,在数据库中,然后调用该函数即可
递归函数如下:特别注意我采用了 LONGTEXT 而不是 VARCHAR(4000),因为数据太大了,不够存,会提示 data too long for column 'xxx' at row 1
CREATE DEFINER=`root`@`localhost` FUNCTION `getDepartChildListById`(rootId INT) RETURNS longtext CHARSET utf8mb3 BEGIN DECLARE sChildList LONGTEXT; DECLARE sChildTemp LONGTEXT; SET sChildTemp =CAST(rootId AS CHAR); WHILE sChildTemp IS NOT NULL DO IF (sChildList IS NOT NULL) THEN SET sChildList = CONCAT(sChildList,',',sChildTemp); ELSE SET sChildList = CONCAT(sChildTemp); END IF; SELECT GROUP_CONCAT(id) INTO sChildTemp FROM sys_depart WHERE FIND_IN_SET(parent_id,sChildTemp)>0; END WHILE; RETURN sChildList; END
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | CREATE DEFINER=`root`@`%` FUNCTION `getDepartChildList`(rootId VARCHAR(8)) RETURNS longtext CHARSET utf8mb4 READS SQL DATA BEGIN #开始 DECLARE sTemp longtext; #定义全局变量,查询出来的id进行拼接 DECLARE sTempChd longtext; #临时变量,用于循环查询的单次接收 SET sTempChd =CAST(rootId AS CHAR); #赋值,进行查询你 #SET sTempChd =rootId ; #赋值,进行查询你 WHILE sTempChd IS NOT NULL DO #此处为循环 为 null 结束循环 IF (sTemp IS NOT NULL) THEN SET sTemp = CONCAT(sTemp, ',' ,sTempChd); #将查询的所有子节点赋值为全局 ELSE SET sTemp = CONCAT(sTempChd); END IF; #GROUP_CONCAT(id) : 将查询出来的结果用逗号连接在一起 #使用find_in_set函数一次返回多条记录 #id 是一个表的字段 然后每条记录分别是id等于1,2,3,4,5的时候 #有点类似in (集合) SELECT GROUP_CONCAT(id) INTO sTempChd FROM sys_depart WHERE FIND_IN_SET(parent_id,sTempChd); #将查询出来的子id, 再次将子id当作父id进行查询 END WHILE; RETURN sTemp; #将最后结果返回出去 END |
然后调用该函数即可查询
1 | select getDepartChildListById(#{pId}) from dual |
以上是我的总结,没有做详细的说明,但是我想如果你遇到此类问题后,看一下应该能明白如果做
附表是关于数据类型比较
每天学习一点点,你就进步一点点。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构