下面是内存溢出 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家谱表查询某人所有后代所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)