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));

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

  • 相关阅读:
    1301班 github安装及账户注册
    对于软件工程课程的疑问
    LeetCode50:Pow
    LeetCode49:字母异位词分组
    LeetCode46:全排列
    LeetCode38:外观数列
    LeetCode:有效的数独
    LeetCode34:在排序数组中查找元素的第一个位置和最后一个位置
    LeetCode33:搜索旋转排序数组
    LeetCode29:两数相除
  • 原文地址:https://www.cnblogs.com/chenyuanbo/p/9843747.html
Copyright © 2011-2022 走看看