300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > MySQL 递归查询树状表的所有子节点 所有父节点具体实现

MySQL 递归查询树状表的所有子节点 所有父节点具体实现

时间:2023-04-06 03:06:33

相关推荐

MySQL 递归查询树状表的所有子节点 所有父节点具体实现

数据库|mysql教程

MySQL,递归,查询,树状,所,节点,具体,实现,程序,

数据库-mysql教程

单车 管理平台源码,ubuntu连接网络dns,tomcat外网下载服务器,易语言爬虫解析,没有用于调试php的扩展,网站seo包月lzw

本程序写了两个sql存储过程,子节点查询算是照搬了,父节点查询是逆思维弄的。 简介:mysql5.0.94版本,该版本以及较高级的版本(5.5、6等等)尚未支持循环递归查询,和sqlserver、oracle相比,mysql难于在树状表中层层遍历的子节点。本程序重点参考了下面的

中介小程序源码,ubuntu+ns2,tomcat的项目保存在哪,中国mooc爬虫,php 使用正则爬取数据,河北seo平台lzw

移动oa源码,ubuntu的插件在哪,爬虫海外代理ip,php猪哥,SEO优化推荐lzw

本程序写了两个sql存储过程,子节点查询算是照搬了,父节点查询是逆思维弄的。

简介:mysql5.0.94版本,该版本以及较高级的版本(5.5、6等等)尚未支持循环递归查询,和sqlserver、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;

/*获取子节点*/

/*调用: 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里面多查几次吧。。。存储结构有很多优点,包括加快查询速度、提高安全性等等,但是会加大数据库负荷,很多文章建议结合使用,个人也觉得少用点会好些。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。