`

mysql 递归查询

 
阅读更多
CREATE TABLE nodelist(  
     id INT PRIMARY KEY,            
     nodename VARCHAR(20),          
     pid INT                         
    );     



    Insert INTO nodelist VALUES(1,'A',null);  //父节点为,即根节点。
    Insert INTO nodelist VALUES(2,'B',1);  
    Insert INTO nodelist VALUES(3,'C',1);  
    Insert INTO nodelist VALUES(4,'D',2);  
    Insert INTO nodelist VALUES(5,'E',3);  
    Insert INTO nodelist VALUES(6,'F',3);  
    Insert INTO nodelist VALUES(7,'G',5);  
    Insert INTO nodelist VALUES(8,'H',7);  
    Insert INTO nodelist VALUES(9,'I',8);  
    Insert INTO nodelist VALUES(10,'J',8); 


CREATE FUNCTION `getChildList`(rootId INT) //rootId为你要查询的节点。
     RETURNS VARCHAR(1000)  
     BEGIN 
       DECLARE pTemp VARCHAR(1000);  
       DECLARE cTemp VARCHAR(1000);  //两个临时变量
      
       SET pTemp = '$';  
       SET cTemp =cast(rootId as CHAR);  //把rootId强制转换为字符。
      
       WHILE cTemp is not null DO  
         SET pTemp = concat(pTemp,',',cTemp);  //把所有节点连接成字符串。
         SELECT group_concat(id) INTO cTemp FROM nodelist   
         WHERE FIND_IN_SET(pid,cTemp)>0; 
                // FIND_IN_SET(str,strlist)的方法网上大把不解释。
       END WHILE;  
       RETURN pTemp;  
     END 
      

select  getChildList(5)

select * from nodelist t where  FIND_IN_SET(id, getChildList(3));




  • 大小: 2.7 KB
分享到:
评论

相关推荐

    MySQL递归查询

    MySQL 递归查询实现方法 MySQL 递归查询是指在 MySQL 中实现类似 Oracle Hierarchical Queries 的功能,用于查询树形结构中的所有子节点。由于 MySQL 目前还没有内置的递归查询功能,因此需要使用其他方法来实现。 ...

    mysql递归查询.doc

    MySQL 递归查询实现多分类查询 MySQL 递归查询是指在 MySQL 数据库中使用递归函数来实现树形结构数据的查询,例如部门表中某个部门的所有下属部分或者某个部分的所有上级部门。 在 MySQL 中实现递归查询需要使用...

    mysql递归查询.txt

    mysql递归查询.txt,里面写了mysql递归查询的例子,方便需要的朋友使用,可读性强,简单实用

    MySQL递归查询树状表的子节点、父节点具体实现

    在MySQL中,处理树状结构的数据表时,由于不直接支持循环递归查询,因此需要采用一些特殊的技巧来实现对子节点和父节点的查找。本例中提到了两个存储过程,分别用于获取树状表中的子节点列表和父节点列表。 1. 获取...

    两种mysql递归tree查询效率-mysql递归tree

    两种mysql递归tree查询效率-mysql递归tree,提供两种递归算法

    SQL如何实现MYSQL的递归查询

    这里我们将探讨如何通过一条SQL语句来实现MySQL的递归查询。 首先,我们需要一个包含层级关系的表格,例如名为`treenodes`的表格,包含字段`id`(节点ID)、`nodename`(节点名称)和`pid`(父节点ID)。为了演示...

    MySQL通过自定义函数实现递归查询父级ID或者子级ID

    在MySQL中,递归查询通常用于处理层次结构的数据,如组织结构、菜单系统或类别树等。当数据的层级关系无法预知或者可能无限深时,传统的JOIN操作可能无法满足需求,此时就需要自定义函数来实现递归查询。本文将详细...

    MySQL实现递归查询的三种方式.rar

    在数据库管理中,递归查询是一种处理层次结构数据的有效方法,尤其在关系型数据库如MySQL中,递归查询可以帮助我们解决树形结构或有层级关系的数据检索问题。本资料主要探讨了MySQL中实现递归查询的三种常见方法:自...

    mysql 递归查询 树型结构 代码逻辑

    mysql 递归查询 树型结构 代码逻辑

Global site tag (gtag.js) - Google Analytics