1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > mysql 递归函数_MySQL 实现递归函数查询

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

时间:2018-10-31 00:54:11

相关推荐

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

利用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);

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

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