zoukankan      html  css  js  c++  java
  • MySQL递归查询父节点或递归查询子节点-陈远波

    根据id查询父节点,具体需要修改的地方笔者已在注释中给大家作了注解

    DELIMITER $$
    
    USE `yjlc_platform`$$
    -- getCompanyParent 为函数名
    DROP FUNCTION IF EXISTS `getCompanyParent`$$
    -- getCompanyParent 为函数名 rootId为参数,可以自定义;初学者可以不用更改
    CREATE DEFINER=`sysdbuser`@`%` FUNCTION `getCompanyParent`(rootId INT(36)) RETURNS VARCHAR(1000) CHARSET utf8
    BEGIN
        DECLARE ptemp VARCHAR(1000);
        DECLARE ctemp VARCHAR(1000);
        SET ptemp = '#';
        SET ctemp = rootId;
        WHILE ctemp IS NOT NULL DO
          SET ptemp = CONCAT(ptemp, ',', ctemp);
          SELECT GROUP_CONCAT(id)
          -- id为主键id
          INTO ctemp
          -- company为查询的哪张表
          FROM company
          -- parent_id为该条数据的父id,根据自己定义的字段进行更改
          WHERE FIND_IN_SET(parent_id, ctemp) > 0;
        END WHILE;
        RETURN ptemp;
      END$$
    
    DELIMITER ;
    
    
    -- 根据函数查询父节点  6为要查询的哪个子节点id
    SELECT * FROM company WHERE FIND_IN_SET(id, getCompanyParent(6));

    根据id查询子节点

    DELIMITER $$
    
    USE `yjlc_platform`$$
    -- COMPANY_CHILD 函数名
    DROP FUNCTION IF EXISTS `COMPANY_CHILD`$$
    CREATE DEFINER=`sysdbuser`@`%` FUNCTION `COMPANY_CHILD`(rootId INT) RETURNS VARCHAR(1000) CHARSET utf8
    BEGIN
        DECLARE sTemp VARCHAR(1000);
        DECLARE sTempChd VARCHAR(1000);
        SET sTemp= '$';
        SET sTempChd =CAST(rootId AS CHAR);
     
            WHILE sTempChd IS NOT NULL DO
              SET sTemp = CONCAT(sTemp,',',sTempChd);
              -- id为主键id company为表名 - parent_id为父id
              SELECT GROUP_CONCAT(id) INTO sTempChd FROM `company` WHERE   FIND_IN_SET(parent_id,sTempChd)>0;
            END WHILE;
            RETURN SUBSTRING(sTemp,3);
        END$$
    DELIMITER ;
    
    -- 根据id查询子节点
    SELECT * FROM company WHERE FIND_IN_SET(id, COMPANY_CHILD(6));

    以上代码仅供参考,若以上代码中有不足的地方请广大博友见谅!

  • 相关阅读:
    go 接收发送文件
    【0031】反转整数/判断回文
    【003】链表或字符串的【反转】【左旋转】
    【002】链表或字符串模拟加法/加一/乘法
    【01】数组中只出现一次的数字
    【面试题050】树中两个结点的最低公共祖先
    【面试题049】把字符串转换成整数
    【面试题048】不能继承的类
    【面试题047】不用加减乘除做加法
    【面试题046】求1+2+...+n
  • 原文地址:https://www.cnblogs.com/chenyuanbo/p/9843747.html
Copyright © 2011-2022 走看看