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

      

    然后调用该函数即可查询

    select getDepartChildListById(#{pId}) from dual
    

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

    附表是关于数据类型比较

  • 相关阅读:
    watchguard 软件工程师内部招聘!
    反脆弱:被雅虎裁掉的为何是他们?
    Linux SSH无密码login
    Makefile选项CFLAGS,LDFLAGS,LIBS
    python 相关编码[转]
    用python处理html代码的转义与还原
    运维部_首席架构师
    Software Engineer(百赴美)
    修改linux文件权限命令:chmod
    How to install Eclipse?
  • 原文地址:https://www.cnblogs.com/zhangliang88/p/15989715.html
Copyright © 2020-2023  润新知