JAVA后端递归构建树结构及使用mybatis构建树结构
目录
(图片来源网络,侵删)
1.说明
2.java示例
3.mybatis示例
1.说明
①获取所有的顶级节点信息
②循环顶级节点信息,寻找每个顶级节点下载子节点,找到子节点后,递归调用寻找子节点的方法
2.java示例
Python
package com.ruoyi.web.controller.tool;
import java.util.ArrayList;
import java.util.List;
/**
* @Author lin
* @Date 2024/4/7 19:02
* @Version 1.0
*/
public class TreeUtils {
public static void main(String[] args) {
List list = new ArrayList();
StudentTree stu1 = new StudentTree();
stu1.setId("1");
stu1.setPid("0");
stu1.setName("名1");
StudentTree stu2 = new StudentTree();
stu2.setId("2");
stu2.setPid("0");
stu2.setName("名2");
StudentTree stu3 = new StudentTree();
stu3.setId("11");
stu3.setPid("1");
stu3.setName("名11");
StudentTree stu4 = new StudentTree();
stu4.setId("12");
stu4.setPid("1");
stu4.setName("名12");
StudentTree stu5 = new StudentTree();
stu5.setId("111");
stu5.setPid("11");
stu5.setName("名111");
StudentTree stu6 = new StudentTree();
stu6.setId("112");
stu6.setPid("11");
stu6.setName("名112");
StudentTree stu7 = new StudentTree();
stu7.setId("21");
stu7.setPid("2");
stu7.setName("名21");
StudentTree stu8 = new StudentTree();
stu8.setId("22");
stu8.setPid("2");
stu8.setName("名22");
StudentTree stu9 = new StudentTree();
stu9.setId("212");
stu9.setPid("21");
stu9.setName("名212");
list.add(stu1);
list.add(stu2);
list.add(stu3);
list.add(stu4);
list.add(stu5);
list.add(stu6);
list.add(stu7);
list.add(stu8);
list.add(stu9);
List studentTrees = buildTree(list);
System.out.println(studentTrees);
}
public static List buildTree(List list){
// 获取最顶级的树节点
List treeList = new ArrayList();
for (StudentTree studentTree : list) {
if("0".equals(studentTree.getPid())){
treeList.add(studentTree);
}
}
// 循环每个顶级节点,查找顶级节点的子节点
for (StudentTree studentTree : treeList) {
buildChild(studentTree, list);
}
return treeList;
}
public static void buildChild(StudentTree student, List list){
List treeList = new ArrayList();
for (StudentTree studentTree : list) {
if(student.getId().equals(studentTree.getPid())){
// 查找到子节点后,递归调用此方法,查找子节点的子节点
buildChild(studentTree,list);
// 将子节点存储到集合中
treeList.add(studentTree);
}
}
// 将查询到的子节点集合设置到child中
student.setChild(treeList);
}
// 树结构实体类
public static class StudentTree{
private String id;
private String pid;
private String name;
private List child;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getPid() {
return pid;
}
public void setPid(String pid) {
this.pid = pid;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List getChild() {
return child;
}
public void setChild(List child) {
this.child = child;
}
}
}
3.mybatis示例
Python
select MENU_ID,PARENT_ID from pf_menu where MENU_ID = #{menuId,jdbcType=INTEGER}
select MENU_ID,PARENT_ID from pf_menu where PARENT_ID = #{parentId,jdbcType=INTEGER}
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!