MySQL递归查询树状表的子节点、父节点
来源:互联网 发布:聚合数据 左磊 编辑:程序博客网 时间:2024/05/16 12:44
本程序写了两个mysql存储过程,子节点查询算是照搬了,父节点查询是逆思维弄的
简介:mysql5.0.94版本,该版本以及较高级的版本(5.5、6等等)尚未支持循环递归查询,和sql数据库、oracle数据库相比,mysql难于在树状表中层层遍历的子节点。本程序重点参考了下面的资料,写了两个sql存储过程,子节点查询算是照搬了,父节点查询是逆思维弄的。
表结构和表数据就不公示了,查询的表user_role,主键是id,每条记录有parentid字段(对应该记录的父节点,当然,一个父节点自然会有一个以上的子节点嘛)
简介:mysql5.0.94版本,该版本以及较高级的版本(5.5、6等等)尚未支持循环递归查询,和sql数据库、oracle数据库相比,mysql难于在树状表中层层遍历的子节点。本程序重点参考了下面的资料,写了两个sql存储过程,子节点查询算是照搬了,父节点查询是逆思维弄的。
表结构和表数据就不公示了,查询的表user_role,主键是id,每条记录有parentid字段(对应该记录的父节点,当然,一个父节点自然会有一个以上的子节点嘛)
CREATE FUNCTION `getChildList`(rootId INT) RETURNS varchar(1000) BEGIN DECLARE sChildList VARCHAR(1000); DECLARE sChildTemp VARCHAR(1000); SET sChildTemp =cast(rootId as CHAR); WHILE sChildTemp is not null DO IF (sChildList is not null) THEN SET sChildList = concat(sChildList,',',sChildTemp); ELSE SET sChildList = concat(sChildTemp); END IF; SELECT group_concat(id) INTO sChildTemp FROM user_role where FIND_IN_SET(parentid,sChildTemp)>0; END WHILE; RETURN sChildList; END; ---(脚本学堂 www.jbxue.com)/*获取子节点*/ /*调用: 1、select getChildList(0) id; 2、select * 5From user_role where FIND_IN_SET(id, getChildList(2));*/ CREATE FUNCTION `getParentList`(rootId INT) RETURNS varchar(1000) BEGIN DECLARE sParentList varchar(1000); DECLARE sParentTemp varchar(1000); SET sParentTemp =cast(rootId as CHAR); WHILE sParentTemp is not null DO IF (sParentList is not null) THEN SET sParentList = concat(sParentTemp,',',sParentList); ELSE SET sParentList = concat(sParentTemp); END IF; SELECT group_concat(parentid) INTO sParentTemp FROM user_role where FIND_IN_SET(id,sParentTemp)>0; END WHILE; RETURN sParentList; END; /*获取父节点*/ /*调用: 1、select getParentList(6) id; 2、select * From user_role where FIND_IN_SET(id, getParentList(2));*/
弄完了,pm说不要弄存储结构,在java里面多查几次吧。
存储结构有很多优点,包括加快查询速度、提高安全性等等,但是会加大数据库负荷,很多文章建议结合使用,个人也觉得少用点会好些。
0 0
- MySQL递归查询树状表的子节点、父节点
- MySQL递归查询树状表的子节点、父节点
- MySQL递归查询树状表的子节点、父节点
- MySQL递归查询树状表的子节点、父节点
- MySQL 递归查询树状表的所有子节点、所有父节点具体实现
- MySQL递归查询树状表的子节点、父节点具体实现
- MySQL递归查询树状表的子节点、父节点具体实现
- mysql递归查询子节点
- mysql 递归查询父节点及子节点
- Mysql中的递归层次查询(根据父节点查找所有的子节点和根据子节点查询所有的父节点)的两种运用
- MySQL中进行树状所有子节点的查询
- MySQL中进行树状所有子节点的查询
- MySQL中进行树状所有子节点的查询
- MySQL中进行树状所有子节点的查询
- MySQL中进行树状所有子节点的查询
- MySQL中进行树状所有子节点的查询
- MySQL中进行树状所有子节点的查询 .
- MySQL中进行树状所有子节点的查询
- 1078. Hashing (25)
- 释构函数的调用顺序
- Permutation Sequence -- LeetCode
- MySQL存储过程相互调用并获得错误码
- Binary Tree Postorder Traversal
- MySQL递归查询树状表的子节点、父节点
- VS C++ 程序中 waitkey 输入按键失效原因
- Datanode denied communication with namenode: DatanodeRegistration 解决办法
- OpenCV笔记(五)CvMat结构体初解2
- 大一想去参加培训的学生
- Cocos2d-x添加音效CocosDenshion
- Android Wear Preview Launcher APK 深度体验(反编译分析和下载)。 作者: Liam Spradlin
- HDU 1548
- 网络121第4周实验——多线程 与 网页下载