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

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

  • 相关阅读:
    python中filter、map、reduce的区别
    Python属性和内建属性
    3分钟学会Python 针对Excel操作
    python重要函数eval
    python中用修饰器进行异常日志记录
    python 生成器中的send、移动平均值、列表表达式相关
    python中如何将字符串连接在一起,多倍的字符串如何输出
    Python将一个已知的utc时间字符串转换为东八区时间
    Python有参函数的使用
    Linux--虚拟环境
  • 原文地址:https://www.cnblogs.com/chenyuanbo/p/9843747.html
Copyright © 2011-2022 走看看