找到父节点下的所有子节点(包括子节点)
Posted tonggc1668
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了找到父节点下的所有子节点(包括子节点)相关的知识,希望对你有一定的参考价值。
CREATE TABLE `tab_menu` ( `MU_ID` int(10) NOT NULL AUTO_INCREMENT COMMENT ‘主键‘, `MU_NAME` varchar(255) NOT NULL COMMENT ‘菜单名‘, `MU_CODE` varchar(100) DEFAULT NULL COMMENT ‘菜单编码‘, `MU_CHAIN_NAME` varchar(255) NOT NULL COMMENT ‘菜单全名‘, `MU_PARENT_ID` int(10) NOT NULL COMMENT ‘上级菜单ID‘, `MU_URL` varchar(255) NOT NULL COMMENT ‘菜单URL‘, `STATUS` smallint(1) NOT NULL DEFAULT ‘1‘ COMMENT ‘状态;0:未启用 1:已启用,默认为1‘, `MU_ELEMENT_TYPE` varchar(40) NOT NULL COMMENT ‘所属元素类型‘, `MU_SCOPE` varchar(20) NOT NULL DEFAULT ‘common‘ COMMENT ‘菜单作用范围;‘, `CREATE_USER_ID` int(11) NOT NULL COMMENT ‘创建用户ID‘, `CREATE_TIME` datetime NOT NULL COMMENT ‘创建时间‘, `UPDATE_USER_ID` int(11) DEFAULT NULL COMMENT ‘修改用户ID‘, `UPDATE_TIME` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT ‘修改时间‘, `VERSION_NUMBER` int(11) NOT NULL DEFAULT ‘0‘ COMMENT ‘版本号:新增资料为 0,每次修改加 1‘, PRIMARY KEY (`MU_ID`), KEY `idx_menu_url` (`MU_URL`) ) ENGINE=InnoDB AUTO_INCREMENT=2040101 DEFAULT CHARSET=utf8 COMMENT=‘菜单‘;
CREATE DEFINER=`ggs`@`%` FUNCTION `pkg_pm_fun_get_children_branch`(menu_id int(10)) RETURNS text CHARSET utf8 COLLATE utf8_bin begin declare menu_ids TEXT; declare tmp_menu_ids text; set tmp_menu_ids =‘$‘; set menu_ids = cast(menu_id as char); while menu_ids is not null do set tmp_menu_ids = concat(tmp_menu_ids,‘,‘,menu_ids); select group_concat(mu_id) into menu_ids from tab_menu where find_in_set(mu_parent_id,menu_ids) > 0; end while; return tmp_menu_ids; end
以上是关于找到父节点下的所有子节点(包括子节点)的主要内容,如果未能解决你的问题,请参考以下文章