JAVA使用hutool工具实现查询树结构数据(省市区)
下面通过代码看下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
到此这篇关于JAVA使用hutool工具实现查询树结构数据(省市区)的文章就介绍到这了,更多相关java查询省市区树结构内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Java中List Set和Map之间的区别_动力节点Java学院整理
Java集合的主要分为三种类型set集,list列表,map映射,接下来通过本文给大家详细介绍java中list、Set和Map之间的区别,需要的的朋友参考下吧2017-05-05java优先队列PriorityQueue中Comparator的用法详解
这篇文章主要介绍了java优先队列PriorityQueue中Comparator的用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-02-02java实现pdf文件截图的方法【附PDFRenderer.jar下载】
这篇文章主要介绍了java实现pdf文件截图的方法,结合实例形式分析了java基于PDFRenderer.jar进行pdf文件截图的相关操作技巧,并附带PDFRenderer.jar文件供读者下载使用,需要的朋友可以参考下2018-01-01Java数据结构及算法实例:冒泡排序 Bubble Sort
这篇文章主要介绍了Java数据结构及算法实例:冒泡排序 Bubble Sort,本文直接给出实现代码,代码中包含详细注释,需要的朋友可以参考下2015-06-06
最新评论