mysql 递归函数_MySQL 实现递归函数查询

这篇博客介绍了如何在MySQL中利用find_in_set()和group_concat()函数进行递归查询,包括向下和向上递归。提供了两个自定义函数queryChildrenMenuInfo和queryChildrenMenuInfo1,分别用于获取菜单项的子菜单和父菜单的完整ID列表。通过调用这两个函数,可以查询指定ID菜单的所有子级或父级ID。
摘要由CSDN通过智能技术生成

利用find_in_set()和group_concat()实现向下递归查询

CREATE FUNCTION queryChildrenMenuInfo(menuId INT)

RETURNS VARCHAR(4000)

BEGIN

DECLARE sTemp VARCHAR(4000);

DECLARE sTempChd VARCHAR(4000);

SET sTemp='$';

SET sTempChd = CAST(menuId AS CHAR);

WHILE sTempChd IS NOT NULL DO

SET sTemp= CONCAT(sTemp,',',sTempChd);

SELECT GROUP_CONCAT(id) INTO sTempChd FROM t_menus WHERE FIND_IN_SET(parentId,sTempChd)>0;

END WHILE;

RETURN sTemp;

END

获取所有id为1的自身和下级:

SELECT queryChildrenMenuInfo(1);

利用find_in_set()和group_concat()实现向上递归查询

CREATE FUNCTION queryChildrenMenuInfo1(menuId INT)

RETURNS VARCHAR(4000)

BEGIN

DECLARE sTemp VARCHAR(16000);

DECLARE sTempChd VARCHAR(16000);

SET sTemp='$';

SET sTempChd = CAST(menuId AS CHAR);

SET sTemp = CONCAT(sTemp,',',sTempChd);

SELECT parentId INTO sTempChd FROM t_menus WHERE id = sTempChd;

WHILE sTempChd <> 0 DO

SET sTemp = CONCAT(sTemp,',',sTempChd);

SELECT parentId INTO sTempChd FROM t_menus WHERE id = sTempChd;

END WHILE;

RETURN sTemp;

END

获取所有id为10的自身和上级:

SELECT queryChildrenMenuInfo1(10);

转载请说明出处:第六感博客 原文链接:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值