mysql家谱表查询某人所有后代

mysql家谱表查询某人所有后代,第1张

概述mysql家谱查询某人所有后代

下面是内存溢出 jb51.cc 通过网络收集整理的代码片段。

内存溢出小编现在分享给大家,也给大家做个参考。

CREATE table `people` (    `ID` INT(11) NOT NulL,`name` VARCHAR(50) NulL DEFAulT NulL,`pID` INT(11) NOT NulL DEFAulT '0',PRIMARY KEY (`ID`));CREATE defineR=`root`@`%` PROCEDURE `getChildren`(IN `parentID` INT)    LANGUAGE sql    NOT DETERMINISTIC    CONTAINS sql    sql Security defineR    COMMENT '获取某人所有后代'BEGIN    #存放结果的临时表    DROP table IF EXISTS children;    CREATE TEMPORARY table children SELECT 0 pLevel,p.* FROM `people` p WHERE ID=parentID;    #存放中间结果的临时表    DROP table IF EXISTS tem;    CREATE TEMPORARY table tem SELECT ID FROM `people` limit 0;        #逐级填充后代    SET @pLevel=1;    REPEAT        #清空上次数据        TruncATE table tem;        #将当前level的后代ID放入临时表        INSERT INTO tem SELECT p.ID FROM `people` P,children c             WHERE p.pID=c.ID AND    c.pLevel=(@pLevel-1);        #将当前level的后代数据塞入结果临时表        INSERT INTO children SELECT @pLevel pLevel,p.* FROM `people` p,tem t         WHERE p.ID=t.ID;        SET @[email protected]+1;    UNTIL NOT EXISTS (SELECT * FROM tem) OR @pLevel > 10    END REPEAT;        #调整表结构,删除临时列和不需要的数据    ALTER table children DROP ColUMN pLevel;    DELETE FROM children WHERE ID=parentID;        #返回结果    SELECT * from children;END

以上是内存溢出(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

总结

以上是内存溢出为你收集整理的mysql家谱表查询某人所有后代全部内容,希望文章能够帮你解决mysql家谱表查询某人所有后代所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1164373.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存