根据父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

  以上是我的总结,没有做详细的说明,但是我想如果你遇到此类问题后,看一下应该能明白如果做

附表是关于数据类型比较

 

posted @   张亮java  阅读(945)  评论(0编辑  收藏  举报
(评论功能已被禁用)
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示