JAVA使用hutool工具实现查询树结构数据(省市区)
作者:唐胜伟 时间:2021-11-04 18:30:09
下面通过代码看下JAVA查询树结构数据(省市区)使用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())) // 父节点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) -> {
// 给树节点赋值(还能set 父 或子节点树)
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
来源:https://www.cnblogs.com/tangshengwei/p/15181115.html
标签:java,查询,树结构,数据
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Android仿微信录制语音功能
2022-10-18 15:54:18
Java基础之数组详解
2021-08-06 08:15:28
![](https://img.aspxhome.com/file/2023/8/114058_0s.png)
使用java的Calendar对象获得当前日期
2023-10-11 16:24:23
Logger.getLogger()与LogFactory.getLog()的区别详解
2021-11-04 19:16:00
Python调用Java可执行jar包问题
2021-06-02 10:26:26
![](https://img.aspxhome.com/file/2023/9/102899_0s.png)
SVN报错:Error Updating changes:svn:E155037的解决方案
2023-06-11 07:27:11
![](https://img.aspxhome.com/file/2023/7/63777_0s.png)
springboot-curd基于mybatis项目搭建
2023-12-08 10:41:05
![](https://img.aspxhome.com/file/2023/3/78343_0s.png)
Struts2+Hibernate实现数据分页的方法
2022-10-28 05:31:13
![](https://img.aspxhome.com/file/2023/8/89578_0s.jpg)
Java发送邮箱验证码、session校验功能
2023-09-11 02:44:21
Android游戏开发:实现手势操作切换图片的实例
2022-05-06 11:55:01
![](https://img.aspxhome.com/file/2023/1/117151_0s.gif)
如何只返回实体类中的部分字段问题
2022-11-28 05:09:53
![](https://img.aspxhome.com/file/2023/2/61282_0s.jpg)
使用java生成字母验证码
2021-10-29 23:50:25
Spring整合mybatis实现过程详解
2022-05-23 02:10:23
![](https://img.aspxhome.com/file/2023/5/71605_0s.png)
Android自定义View实现自动转圈效果
2021-11-11 21:01:48
java 将一个数组逆序输出的方法
2023-05-09 09:29:01
React-Native之Android(6.0及以上)权限申请详解
2023-07-28 01:56:55
![](https://img.aspxhome.com/file/2023/8/85998_0s.jpg)
java遍历properties文件操作指南
2023-11-23 02:43:45
Java Durid进行JDBC连接详解
2022-09-25 02:35:12
Java 数据结构与算法系列精讲之栈
2021-06-11 09:00:51
![](https://img.aspxhome.com/file/2023/1/81361_0s.gif)
图解红黑树及Java进行红黑二叉树遍历的方法
2023-04-20 22:09:14
![](https://img.aspxhome.com/file/2023/1/83021_0s.png)