必威体育Betway必威体育官网
当前位置:首页 > IT技术

mysql的递归查询

时间:2019-08-09 05:41:11来源:IT技术作者:seo实验室小编阅读:76次「手机版」
 

递归查询

描述:最近遇到了一个问题,在mysql中如何完成节点下的所有节点或节点上的所有父节点的查询? 在oracle中我们知道有一个Hierarchical Queries可以通过CONNECT BY来查询,但是,在MySQL中还没有对应的函数!!! 下面给出一个function来完成的方法 下面是sql脚本,想要运行的直接赋值粘贴进数据库即可。

好记性不如烂笔头

下面给出一个function来完成的方法

下面是sql脚本,想要运行的直接赋值粘贴进数据库即可。

创建表treenodes(可以根据需要进行更改)


– Table structure for treenodes


DROP TABLE IF exists treenodes;

CREATE TABLE treenodes (

id int(11) NOT NULL,

nodename varchar(20) DEFAULT NULL,

pid int(11) DEFAULT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=latin1;


– Table structure for treenodes


插入几条数据


– Records of treenodes


INSERT INTO treenodes VALUES (‘1’, ‘A’, ‘0’);

INSERT INTO treenodes VALUES (‘2’, ‘B’, ‘1’);

INSERT INTO treenodes VALUES (‘3’, ‘C’, ‘1’);

INSERT INTO treenodes VALUES (‘4’, ‘D’, ‘2’);

INSERT INTO treenodes VALUES (‘5’, ‘E’, ‘2’);

INSERT INTO treenodes VALUES (‘6’, ‘F’, ‘3’);

INSERT INTO treenodes VALUES (‘7’, ‘G’, ‘6’);

INSERT INTO treenodes VALUES (‘8’, ‘H’, ‘0’);

INSERT INTO treenodes VALUES (‘9’, ‘I’, ‘8’);

INSERT INTO treenodes VALUES (‘10’, ‘J’, ‘8’);

INSERT INTO treenodes VALUES (‘11’, ‘K’, ‘8’);

INSERT INTO treenodes VALUES (‘12’, ‘L’, ‘9’);

INSERT INTO treenodes VALUES (‘13’, ‘M’, ‘9’);

INSERT INTO treenodes VALUES (‘14’, ‘N’, ‘12’);

INSERT INTO treenodes VALUES (‘15’, ‘O’, ‘12’);

INSERT INTO treenodes VALUES (‘16’, ‘P’, ‘15’);

INSERT INTO treenodes VALUES (‘17’, ‘Q’, ‘15’);

把下面的语句直接粘贴进命令行执行即可(注意修改传入的参数,默认rootId,表明默认treenodes)

根据传入id查询所有父节点的id

delimiter // 
CREATE FUNCTION `getParList`(rootId INT)
RETURNS varchar(1000) 
BEGIN
    DECLARE sTemp VARCHAR(1000);
    DECLARE sTempPar VARCHAR(1000); 
    SET sTemp = ''; 
    SET sTempPar =rootId; 

    #循环递归
    while sTempPar is not null DO 
        #判断是否是第一个,不加的话第一个会为空
        IF sTemp != '' THEN
            SET sTemp = concat(sTemp,',',sTempPar);
        ELSE
            SET sTemp = sTempPar;
        END IF;
        SET sTemp = concat(sTemp,',',sTempPar); 
        SELECT group_concat(pid) INTO sTempPar FROM treenodes where pid<>id and FIND_IN_SET(id,sTempPar)>0; 
    END WHILE; 

RETURN sTemp; 
END
//

执行命令

select * from treenodes where FIND_IN_SET(id,getParList(15)); //直接运行就可以了  id为表本来的id 15为父级id

结果:

这里写图片描述

根据传入id查询所有子节点的id

delimiter // 
CREATE FUNCTION `getChildList`(rootId INT)
RETURNS varchar(1000) 

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);
        SELECT group_concat(id) INTO sTempChd FROM  treeNodes where FIND_IN_SET(pid,sTempChd)>0;
    END WHILE;
    RETURN sTemp; 
END
//

执行命令

select * from treenodes where FIND_IN_SET(id,getChildList(7));

结果:

这里写图片描述

转载自:https://blog.csdn.net/zhangpengself520/article/details/77451805

相关阅读

mysql-front 下载安装

下载地址:https://mysql-front.en.softonic.com/ 点击下图位置 再点击下图位置: 即可开始下载。 下一步安装即可。 运行软件: 即

MySQL中日期转换 FROM_UNIXTIME和UNIX_TIMESTAMP

MySQL中日期转换

MySql 笛卡儿积

笛卡儿积实际上就是数学中的排列组合。假设集合A={a, b},集合B={0, 1, 2},则两个集合的笛卡尔积为{(a, 0), (a, 1), (a, 2), (b, 0)

常用MySQL图形化管理工具

MySQL的管理维护工具非常多,除了系统自带的命令行管理工具之外,还有许多其他的图形化管理工具,这里我介绍几个经常使用的MySQL图形化

MySQL的时间差函数TIMESTAMPDIFF、DATEDIFF的用法

MySQL的时间差函数TIMESTAMPDIFF、DATEDIFF的用法时间差函数TIMESTAMPDIFF、DATEDIFF的用法我们在写sql语句,尤其是存储过程中,会频

分享到:

栏目导航

推荐阅读

热门阅读