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

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

  • 相关阅读:
    缓存架构设计细节二三事
    数据库软件架构设计些什么
    100亿数据1万属性数据架构设计
    这才是真正的表扩展方案
    啥,又要为表增加一列属性?
    究竟啥才是互联网架构“高可用”
    究竟啥才是互联网架构“高并发”
    Linux用过的命令
    Xshell远程连接工具
    oracle分组取第一条
  • 原文地址:https://www.cnblogs.com/chenyuanbo/p/9843747.html
Copyright © 2011-2022 走看看