java遞歸實現(xiàn)樹形結(jié)構(gòu)數(shù)據(jù)完整案例
前言
本文提供兩種遞歸實現(xiàn)思路
樹形結(jié)構(gòu)數(shù)據(jù),大體的實現(xiàn)思路就是“父找子”,父節(jié)點去層層遞歸尋找子節(jié)點,最后組裝成數(shù)據(jù)集合。
提示:以下是本篇文章正文內(nèi)容,下面案例可供參考
一、樹形結(jié)構(gòu)是什么?
樹形結(jié)構(gòu),和我們平常所觸及到的無限級菜單,是同一個道理。
所謂樹形結(jié)構(gòu),我們可以將其理解為:樹根或者樹冠,都可以無限分叉下去。
現(xiàn)有一張表,需要對表中數(shù)據(jù)進行分級查詢(按照上下級關(guān)系進行排列),我們常用的數(shù)據(jù)庫有: oracle和mysql;
如果使用oracle的話,使用connect by,很容易就能做到;
但是,mysql沒有現(xiàn)成的遞歸函數(shù),需要我們自己使用存儲過程封裝,而且,就算封裝好了遞歸函數(shù),mysql在執(zhí)行的時候,查詢速度會很慢。如何解決這個問題呢?
既然數(shù)據(jù)庫不給力,我們只能交由程序來處理了,以減輕mysql數(shù)據(jù)庫的壓力。
二、實現(xiàn)方案
1、stream流遞歸實現(xiàn)
1.1 實體類
public class TreeBean {
/**
* id
*/
private Integer id;
/**
* 名稱
*/
private String name;
/**
* 父id ,根節(jié)點為0
*/
public Integer parentId;
/**
* 子節(jié)點信息
*/
public List<TreeBean> childList;
public TreeBean() {
}
public TreeBean(Integer id, String name, Integer parentId, List<TreeBean> childList) {
this.id = id;
this.name = name;
this.parentId = parentId;
this.childList = childList;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getParentId() {
return parentId;
}
public void setParentId(Integer parentId) {
this.parentId = parentId;
}
public List<TreeBean> getChildList() {
return childList;
}
public void setChildList(List<TreeBean> childList) {
this.childList = childList;
}
/**
* 初始化數(shù)據(jù)
* @return
*/
public List<TreeBean> initializationData() {
List<TreeBean> list = new ArrayList<>();
TreeBean t1 = new TreeBean(1, "廣東省", 0, new ArrayList<>());
TreeBean t2 = new TreeBean(2, "湖南省", 0, new ArrayList<>());
TreeBean t3 = new TreeBean(3, "廣州市", 1, new ArrayList<>());
TreeBean t4 = new TreeBean(4, "長沙市", 2, new ArrayList<>());
TreeBean t5 = new TreeBean(5, "白云區(qū)", 3, new ArrayList<>());
TreeBean t6 = new TreeBean(6, "黃浦區(qū)", 3, new ArrayList<>());
TreeBean t7 = new TreeBean(7, "白云街道", 5, new ArrayList<>());
TreeBean t8 = new TreeBean(8, "深圳市", 1, new ArrayList<>());
TreeBean t9 = new TreeBean(9, "寶安區(qū)", 8, new ArrayList<>());
TreeBean t10 = new TreeBean(10, "福田區(qū)", 8, new ArrayList<>());
TreeBean t11 = new TreeBean(11, "南山區(qū)", 8, new ArrayList<>());
TreeBean t12 = new TreeBean(12, "南山街道", 11, new ArrayList<>());
TreeBean t13 = new TreeBean(13, "芙蓉區(qū)", 4, new ArrayList<>());
TreeBean t14 = new TreeBean(14, "岳麓區(qū)", 4, new ArrayList<>());
TreeBean t15 = new TreeBean(15, "開福區(qū)", 4, new ArrayList<>());
TreeBean t16 = new TreeBean(16, "岳陽市", 2, new ArrayList<>());
TreeBean t17 = new TreeBean(17, "岳麓街道", 14, new ArrayList<>());
list.add(t1);
list.add(t2);
list.add(t3);
list.add(t4);
list.add(t5);
list.add(t6);
list.add(t7);
list.add(t8);
list.add(t9);
list.add(t10);
list.add(t11);
list.add(t12);
list.add(t13);
list.add(t14);
list.add(t15);
list.add(t16);
list.add(t17);
return list;
}
}
1.2 實現(xiàn)類
/**
* 方式一:Stream流遞歸實現(xiàn)遍歷樹形結(jié)構(gòu)
*/
public static void treeTest1() {
//獲取數(shù)據(jù)
List<TreeBean> treeBeans = new TreeBean().initializationData();
//獲取父節(jié)點
List<TreeBean> collect = treeBeans.stream().filter(t -> t.getParentId() == 0).map(
m -> {
m.setChildList(getChildren(m, treeBeans));
return m;
}
).collect(Collectors.toList());
System.out.println(JSON.toJSONString(collect));
}
/**
* 遞歸查詢子節(jié)點
* @param root 根節(jié)點
* @param all 所有節(jié)點
* @return 根節(jié)點信息
*/
public static List<TreeBean> getChildren(TreeBean root, List<TreeBean> all) {
List<TreeBean> children = all.stream().filter(t -> {
return Objects.equals(t.getParentId(), root.getId());
}).map(
m -> {
m.setChildList(getChildren(m, all));
return m;
}
).collect(Collectors.toList());
return children;
}2、jdk1.7以下實現(xiàn)
2.1 節(jié)點類
便于提供前端取值

2.2 實現(xiàn)類


3、應(yīng)用場景
3.1 用于前端方便展示

3.2 用于查找并構(gòu)建子節(jié)點數(shù)據(jù)
以刪除菜單做例子,一般菜單未免會帶子菜單,所以,“父找子” 需求應(yīng)聲而來;

代碼如下:


總結(jié)
資料參考:
到此這篇關(guān)于java遞歸實現(xiàn)樹形結(jié)構(gòu)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)java遞歸樹形結(jié)構(gòu)數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java 遞歸查詢部門樹形結(jié)構(gòu)數(shù)據(jù)的實踐
- java返回前端樹形結(jié)構(gòu)數(shù)據(jù)的2種實現(xiàn)方式
- 詳解如何使用Java流API構(gòu)建樹形結(jié)構(gòu)數(shù)據(jù)
- java父子節(jié)點parentid樹形結(jié)構(gòu)數(shù)據(jù)的規(guī)整
- Java?處理樹形結(jié)構(gòu)數(shù)據(jù)的過程
- Java樹形結(jié)構(gòu)數(shù)據(jù)生成導出excel文件方法記錄
- Java如何使用遞歸查詢多級樹形結(jié)構(gòu)數(shù)據(jù)(多級菜單)
相關(guān)文章
IDEA無法識別相關(guān)module模塊問題的解決過程
這篇文章主要給大家介紹了關(guān)于IDEA無法識別相關(guān)module模塊問題的解決過程,文中通過圖文介紹的非常詳細,對大家學習或者使用IDEA具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07

