JAVA使用hutool工具實(shí)現(xiàn)查詢樹(shù)結(jié)構(gòu)數(shù)據(jù)(省市區(qū))
下面通過(guò)代碼看下JAVA查詢樹(shù)結(jié)構(gòu)數(shù)據(jù)(省市區(qū))使用hutool工具實(shí)現(xiàn)
代碼:
@PostMapping("/getTree") public Object getTree() { // 查詢數(shù)據(jù) List<LxhpArea> areaList = areaService.list(); // 構(gòu)建的整個(gè)樹(shù)數(shù)據(jù) List<TreeNode<String>> treeNodeList = areaList.stream().map(area -> { // 擴(kuò)展字段賦值,下面要取這里的值 Map<String, Object> extraMap = new HashMap<>(); extraMap.put("domain", area.getDomain()); extraMap.put("isOpen", area.getIsOpen()); extraMap.put("bigArea", area.getBigArea()); // 單個(gè)樹(shù)數(shù)據(jù)構(gòu)建 TreeNode<String> treeNode = new TreeNode<String>() .setId(String.valueOf(area.getId())) // 主鍵 .setParentId(String.valueOf(area.getReid())) // 父節(jié)點(diǎn)ID .setName(area.getName()) // 省份名稱(chēng) .setWeight(area.getSortOrder()) //權(quán)重,排序 .setExtra(extraMap); // 擴(kuò)展字段 return treeNode; }).collect(Collectors.toList()); // 配置 TreeNodeConfig treeNodeConfig = new TreeNodeConfig(); // 自定義屬性名(修改默認(rèn)名稱(chēng)) treeNodeConfig.setWeightKey("sortOrder"); treeNodeConfig.setChildrenKey("childrenNode"); // 最大遞歸深度 treeNodeConfig.setDeep(1); //轉(zhuǎn)換器 List<Tree<String>> treeNodes = TreeUtil.build(treeNodeList, "1", treeNodeConfig, (treeNode, tree) -> { // 給樹(shù)節(jié)點(diǎn)賦值(還能set 父 或子節(jié)點(diǎn)樹(shù)) tree.setId(treeNode.getId()); tree.setParentId(treeNode.getParentId()); tree.setWeight(treeNode.getWeight()); tree.setName(treeNode.getName()); // 擴(kuò)展屬性值賦值 // treeNode.getExtra().getOrDefault("domain", null) 是獲取上面Map放進(jìn)去的值,沒(méi)有就是 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); }
表結(jié)構(gòu)
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;
數(shù)據(jù)結(jié)構(gòu):
官方文檔: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
到此這篇關(guān)于JAVA使用hutool工具實(shí)現(xiàn)查詢樹(shù)結(jié)構(gòu)數(shù)據(jù)(省市區(qū))的文章就介紹到這了,更多相關(guān)java查詢省市區(qū)樹(shù)結(jié)構(gòu)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot實(shí)現(xiàn)quartz定時(shí)任務(wù)可視化管理功能
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)quartz定時(shí)任務(wù)可視化管理功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08基于java實(shí)現(xiàn)停車(chē)場(chǎng)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于java實(shí)現(xiàn)停車(chē)場(chǎng)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11Java中List Set和Map之間的區(qū)別_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
Java集合的主要分為三種類(lèi)型set集,list列表,map映射,接下來(lái)通過(guò)本文給大家詳細(xì)介紹java中l(wèi)ist、Set和Map之間的區(qū)別,需要的的朋友參考下吧2017-05-05java優(yōu)先隊(duì)列PriorityQueue中Comparator的用法詳解
這篇文章主要介紹了java優(yōu)先隊(duì)列PriorityQueue中Comparator的用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02Java實(shí)現(xiàn)的程序員老黃歷實(shí)例
這篇文章主要介紹了Java實(shí)現(xiàn)的程序員老黃歷實(shí)例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-05-05MyBatis找不到mapper文件的實(shí)現(xiàn)
這篇文章主要介紹了MyBatis找不到mapper文件的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10java實(shí)現(xiàn)pdf文件截圖的方法【附PDFRenderer.jar下載】
這篇文章主要介紹了java實(shí)現(xiàn)pdf文件截圖的方法,結(jié)合實(shí)例形式分析了java基于PDFRenderer.jar進(jìn)行pdf文件截圖的相關(guān)操作技巧,并附帶PDFRenderer.jar文件供讀者下載使用,需要的朋友可以參考下2018-01-01Java數(shù)據(jù)結(jié)構(gòu)及算法實(shí)例:冒泡排序 Bubble Sort
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)及算法實(shí)例:冒泡排序 Bubble Sort,本文直接給出實(shí)現(xiàn)代碼,代碼中包含詳細(xì)注釋,需要的朋友可以參考下2015-06-06