JAVA使用hutool工具實現查詢樹結構數據(省市區(qū))
下面通過代碼看下JAVA查詢樹結構數據(省市區(qū))使用hutool工具實現
代碼:
@PostMapping("/getTree")
public Object getTree() {
// 查詢數據
List<LxhpArea> areaList = areaService.list();
// 構建的整個樹數據
List<TreeNode<String>> treeNodeList = areaList.stream().map(area -> {
// 擴展字段賦值,下面要取這里的值
Map<String, Object> extraMap = new HashMap<>();
extraMap.put("domain", area.getDomain());
extraMap.put("isOpen", area.getIsOpen());
extraMap.put("bigArea", area.getBigArea());
// 單個樹數據構建
TreeNode<String> treeNode = new TreeNode<String>()
.setId(String.valueOf(area.getId())) // 主鍵
.setParentId(String.valueOf(area.getReid())) // 父節(jié)點ID
.setName(area.getName()) // 省份名稱
.setWeight(area.getSortOrder()) //權重,排序
.setExtra(extraMap); // 擴展字段
return treeNode;
}).collect(Collectors.toList());
// 配置
TreeNodeConfig treeNodeConfig = new TreeNodeConfig();
// 自定義屬性名(修改默認名稱)
treeNodeConfig.setWeightKey("sortOrder");
treeNodeConfig.setChildrenKey("childrenNode");
// 最大遞歸深度
treeNodeConfig.setDeep(1);
//轉換器
List<Tree<String>> treeNodes = TreeUtil.build(treeNodeList, "1", treeNodeConfig,
(treeNode, tree) -> {
// 給樹節(jié)點賦值(還能set 父 或子節(jié)點樹)
tree.setId(treeNode.getId());
tree.setParentId(treeNode.getParentId());
tree.setWeight(treeNode.getWeight());
tree.setName(treeNode.getName());
// 擴展屬性值賦值
// treeNode.getExtra().getOrDefault("domain", null) 是獲取上面Map放進去的值,沒有就是 null
tree.putExtra("domain", treeNode.getExtra().getOrDefault("domain", null));
tree.putExtra("isOpen", treeNode.getExtra().getOrDefault("isOpen", null));
tree.putExtra("bigArea", treeNode.getExtra().getOrDefault("bigArea", null));
});
return JSONUtil.parse(treeNodes);
}
表結構
CREATE TABLE `lxhp_area` ( `id` smallint(5) unsigned NOT NULL AUTO_INCREMENT, `reid` smallint(5) unsigned NOT NULL DEFAULT '0', `name` varchar(120) NOT NULL DEFAULT '', `sort_order` smallint(5) unsigned NOT NULL DEFAULT '0', `is_open` tinyint(3) unsigned NOT NULL DEFAULT '0', `domain` varchar(10) NOT NULL, `big_area` int(4) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=3433 DEFAULT CHARSET=utf8;
數據結構:

官方文檔:https://hutool.cn/docs/#/core/%E8%AF%AD%E8%A8%80%E7%89%B9%E6%80%A7/%E6%A0%91%E7%BB%93%E6%9E%84/%E6%A0%91%E7%BB%93%E6%9E%84%E5%B7%A5%E5%85%B7-TreeUtil
到此這篇關于JAVA使用hutool工具實現查詢樹結構數據(省市區(qū))的文章就介紹到這了,更多相關java查詢省市區(qū)樹結構內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java中List Set和Map之間的區(qū)別_動力節(jié)點Java學院整理
Java集合的主要分為三種類型set集,list列表,map映射,接下來通過本文給大家詳細介紹java中l(wèi)ist、Set和Map之間的區(qū)別,需要的的朋友參考下吧2017-05-05
java優(yōu)先隊列PriorityQueue中Comparator的用法詳解
這篇文章主要介紹了java優(yōu)先隊列PriorityQueue中Comparator的用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02
java實現pdf文件截圖的方法【附PDFRenderer.jar下載】
這篇文章主要介紹了java實現pdf文件截圖的方法,結合實例形式分析了java基于PDFRenderer.jar進行pdf文件截圖的相關操作技巧,并附帶PDFRenderer.jar文件供讀者下載使用,需要的朋友可以參考下2018-01-01
Java數據結構及算法實例:冒泡排序 Bubble Sort
這篇文章主要介紹了Java數據結構及算法實例:冒泡排序 Bubble Sort,本文直接給出實現代碼,代碼中包含詳細注釋,需要的朋友可以參考下2015-06-06

