mysql如何查询子节点

mysql如何查询子节点,第1张

概述mysql如何查询节点

mySQL查询子节点的方法:首先创建menu表,并插入数据;然后使用语句进行查询,代码为【select ID from(select t1.ID,if(find_in_set(parent_ID, @pIDs) > 0......)】。

更多相关免费学习推荐:mysql教程(视频)

mySQL查询子节点的方法:

创建menu表:

CREATE table `menu` (  `ID` int(11) NOT NulL auto_INCREMENT COMMENT '菜单ID',  `parent_ID` int(11) DEFAulT NulL COMMENT '父节点ID',  `menu_name` varchar(128) DEFAulT NulL COMMENT '菜单名称',  `menu_url` varchar(128) DEFAulT '' COMMENT '菜单路径',  `status` tinyint(3) DEFAulT '1' COMMENT '菜单状态 1-有效;0-无效',  PRIMARY KEY (`ID`)) ENGINE=InnoDB auto_INCREMENT=12212 DEFAulT CHARSET=utf8;

插入数据:

INSERT INTO `menu` VALUES ('0', null, '菜单0', ' ', '1');INSERT INTO `menu` VALUES ('1', '0', '菜单1', '', '1');INSERT INTO `menu` VALUES ('11', '1', '菜单11', '', '1');INSERT INTO `menu` VALUES ('12', '1', '菜单12', '', '1');INSERT INTO `menu` VALUES ('13', '1', '菜单13', '', '1');INSERT INTO `menu` VALUES ('111', '11', '菜单111', '', '1');INSERT INTO `menu` VALUES ('121', '12', '菜单121', '', '1');INSERT INTO `menu` VALUES ('122', '12', '菜单122', '', '1');INSERT INTO `menu` VALUES ('1221', '122', '菜单1221', '', '1');INSERT INTO `menu` VALUES ('1222', '122', '菜单1222', '', '1');INSERT INTO `menu` VALUES ('12211', '1222', '菜单12211', '', '1');

得到的目录结构如下图所示:

查询

先贴出SQL语句:

select ID from (              select t1.ID,              if(find_in_set(parent_ID, @pIDs) > 0, @pIDs := concat(@pIDs, ',', ID), 0) as ischild              from (                   select ID,parent_ID from re_menu t where t.status = 1 order by parent_ID, ID                  ) t1,                  (select @pIDs := 要查询的菜单节点 ID) t2             ) t3 where ischild != 0

比如,要查询菜单节点12的所有子节点,则查处的结果为:

总结

以上是内存溢出为你收集整理的mysql如何查询子节点全部内容,希望文章能够帮你解决mysql如何查询子节点所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1150676.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存