`

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 递归查询知识点详解 #### 一、MySQL 递归查询概述 在数据库查询中,递归查询主要用于处理层级或树形结构的数据。这类数据的特点是每一项记录不仅包含自身的信息,还可能与其他记录形成上下级关系。MySQL...

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

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

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

    本文将介绍并比较以下两种MySQL递归查询方法: 1. **使用自连接和递归联合(RECURSIVE UNION)**:这种方法通过将表与自身连接,并通过递归地应用联合查询来构建层级结构。 2. **利用变量和循环**:这种方法通过在...

    SQL如何实现MYSQL的递归查询

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

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

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

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

    通过上述分析,我们可以看出MySQL递归查询结合Java代码能够高效地构建出树形结构。这种方法不仅适用于MySQL,对于其他支持递归查询的数据库也同样适用。在实际项目开发中,合理利用递归查询能够极大地简化对层次结构...

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

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

Global site tag (gtag.js) - Google Analytics