Mysql创建递归型的存储过程_MySQL

php中文网
发布: 2016-06-01 13:37:24
原创
1439人浏览过

bitsCN.com

mysql创建递归型的存储过程

 

第一步:SET max_sp_recursion_depth=12;

第二步:创建createChildDept过程

Sql代码      

DELIMITER $$  

  

USE `zhiku`$$  

  

DROP PROCEDURE IF EXISTS `createChildDept`$$  

  

CREATE DEFINER=`root`@`%` PROCEDURE `createChildDept`(IN rootId INT,IN nDepth INT)  

BEGIN  

    DECLARE done INT DEFAULT 0;  

    DECLARE b INT;  

    DECLARE cur1 CURSOR FOR SELECT id FROM zk_departments WHERE parent_id=rootId;  

    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;  

    INSERT INTO tmpLst VALUES (NULL,rootId,nDepth);  

    OPEN cur1;  

    FETCH cur1 INTO b;  

    WHILE done=0 DO  

        CALL createChildDept(b,nDepth+1);  

        FETCH cur1 INTO b;  

    END WHILE;  

    CLOSE cur1;  

存了个图
存了个图

视频图片解析/字幕/剪辑,视频高清保存/图片源图提取

存了个图 17
查看详情 存了个图

    END$$  

  

DELIMITER ;  

 第三步:创建showChildDept

Sql代码      

DELIMITER $$  

  

USE `zhiku`$$  

  

DROP PROCEDURE IF EXISTS `showChildDept`$$  

  

CREATE DEFINER=`root`@`%` PROCEDURE `showChildDept`(IN rootId INT)  

BEGIN  

    CREATE TEMPORARY TABLE IF NOT EXISTS tmpLst  

    (sno INT PRIMARY KEY AUTO_INCREMENT,id INT,depth INT);  

    DELETE FROM tmpLst;  

    CALL createChildDept(rootId,0);  

    SELECT zk_departments.id,zk_departments.name FROM tmpLst,zk_departments WHERE tmpLst.id=zk_departments.id AND zk_departments.id>rootId ORDER BY tmpLst.sno;  

    #select zk_user_departments.dept_id,zk_user_departments.user_id from zk_user_departments left join tmpLst on tmpLst.id=zk_user_departments.dept_id and zk_user_departments.dept_id>rootId order by tmpLst.sno;  

    END$$  

  

DELIMITER ;  

 第四步:CALL showChildDept(128)
 

bitsCN.com
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号