2种方法将集合数据List构建成树形结构

文章目录

  • 递归循环构建树结构
  • hutool.TreeUtil.build构建树结构

在这里插入图片描述

递归循环构建树结构

先查最外层树节点数据,再递归遍历每一层子节点数据

public ApiResultDto<List<LocationDto>> getTreeByParams(LocationSearchDto searchDto, SecurityUser user) {// 最外层的树结构【此最外层是BUILDING,也就是BUILDING的parentId为null】,不是获取所有数据,与下不同searchDto.setProjectId(user.getProjectId());searchDto.setType(LocationType.BUILDING);List<LocationEntity> locationEntities = locationDao.findByParams(searchDto);List<LocationDto> locationDtos = locationEntities.stream().map(t -> {LocationDto dto = new LocationDto();dto.setId(t.getId());dto.setName(t.getName());dto.setType(t.getType());dto.setSort(t.getSort());dto.setSerialNum(t.getSerialNum());dto.setCode(t.getCode());dto.setParentId(t.getParentId());// 循环递归获取子节点iterChild(dto, user.getProjectId());return dto;}).collect(Collectors.toList());return ApiResultDto.success(locationDtos);}/*** 遍历子节点.** @param dto 空间dto*/private void iterChild(LocationDto dto, UUID projectId) {
//  <select id="findChildById"
//        parameterType="map" resultType="common.po.location.LocationEntity">
//        select *
//        from location
//        where model_status = 1
//        and parent_id = #{id}
//    </select>List<LocationEntity> locations = locationDao.findChildById(dto.getId());if (CollectionUtils.isEmpty(locations)) {return;}List<LocationDto> locationDtos = locations.stream().map(t -> {LocationDto childDto = new LocationDto();childDto.setId(t.getId());childDto.setName(t.getName());childDto.setType(t.getType());childDto.setSort(t.getSort());childDto.setSerialNum(t.getSerialNum());childDto.setCode(t.getCode());childDto.setParentId(t.getParentId());// 递归遍历子节点iterChild(childDto, projectId);return childDto;}).collect(Collectors.toList());dto.setChildren(locationDtos);}

hutool.TreeUtil.build构建树结构

   public ApiResultDto<List<Tree<UUID>>> getTreeByParams(LocationSearchDto searchDto, SecurityUser user) {// 查询到所有数据searchDto.setProjectId(user.getProjectId());List<LocationEntity> entities = locationDao.findByParams(searchDto);// 获取非第一层"BUILDING"的数据的父级信息【查询到子节点,要带出对应的所有父节点,如果不需要可以删除】List<LocationEntity> locationEntities = new ArrayList<>();locationEntities.addAll(entities);for (LocationEntity entity : entities) {addParentEntities(entity, locationEntities);}locationEntities = locationEntities.stream().distinct().collect(Collectors.toList());// 构建树,主要数据在treeNode中,其余数据在extra字段中List<TreeNode<UUID>> nodeList = new ArrayList<>();for (LocationEntity entity : locationEntities) {TreeNode<UUID> treeNode = new TreeNode<>(entity.getId(), entity.getParentId(), entity.getName(), null);nodeList.add(treeNode);Map<String, Object> extra = new HashMap<>();extra.put("name", entity.getName());extra.put("serialNum", entity.getSerialNum());extra.put("code", entity.getCode());extra.put("type", entity.getType());extra.put("sort", entity.getSort());if (MapUtils.isNotEmpty(extra)) {treeNode.setExtra(extra);}}List<Tree<UUID>> result = TreeUtil.build(nodeList, null);return ApiResultDto.success(result);}/*** 获取当前空间实体额所有上级实体.** @param entity 当前空间实体* @param res    结果*/private void addParentEntities(LocationEntity entity, List<LocationEntity> res) {if (Objects.nonNull(entity) && Objects.nonNull(entity.getParentId())) {LocationEntity parentEntity = locationDao.selectById(entity.getParentId());if (Objects.nonNull(parentEntity)) {res.add(parentEntity);addParentEntities(parentEntity, res);}}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/18522.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

柔性自驱动生物“电子衣”促进伤口愈合

引用信息 文 章&#xff1a;Combined Amniotic Membrane and Self-Powered Electrical Stimulator Bioelectronic Dress Promotes Wound Healing 期 刊&#xff1a;ACS Applied Materials & Interfaces&#xff08;影响因子&#xff1a;9.5&#xff09; 发表时间…

如何高效搜索?99%的人都不知道的搜索进阶小技巧

如何高效搜索任何你想要的信息&#xff1f; 比如怎么找第一手的行业研究报告&#xff1f; 在哪查高清无码的图片素材&#xff1f; 怎么搜最新的AI工具教程&#xff1f; 遇到以上问题你会怎么搜&#xff1f; 可能大部分人都是直接打开百度查关键词&#xff0c;虽然随便一搜…

【贪心算法】C++ 解决算法题:买卖股票 / K次取反 / 按身高排序 / 优势洗牌

1. 前言 1.1 贪心算法介绍 贪心算法&#xff08;Greedy Algorithm&#xff09;是一种在每一步选择中都采取当前状态下最优决策的算法。贪心算法通常用来解决最优化问题&#xff0c;其核心思想是通过局部最优解逐步推导出全局最优解。 在贪心算法中&#xff0c;我们并不总是考…

Java面试进阶指南:高级知识点问答精粹(一)

Java 面试问题及答案 1. 什么是Java中的集合框架&#xff1f;它包含哪些主要接口&#xff1f; 答案&#xff1a; Java集合框架是一个设计用来存储和操作大量数据的统一的架构。它提供了一套标准的接口和类&#xff0c;使得我们可以以一种统一的方式来处理数据集合。集合框架主…

云计算-交互式数据处理 (Interactive Data Processing)

AWS Glue DataBrew (AWS Glue DataBrew) 数据预处理是任何数据分析任务之前的重要步骤。AWS Glue DataBrew 是一个可视化工具&#xff0c;允许我们预处理数据&#xff0c;包括清洗和规范化数据。此AWS服务提供许多数据准备功能&#xff0c;包括分组、联接、过滤、重新采样、排序…

【数据结构(邓俊辉)学习笔记】二叉树04——Huffman树

文章目录 0. 概述1. 无前缀冲突编码2. 编码成本3. 带权编码成本4. 编码算法5. 算法实现流程6. 时间复杂度与改进方案 0. 概述 学习Huffman树。 1. 无前缀冲突编码 在加载到信道上之前&#xff0c;信息被转换为二进制形式的过程称作编码&#xff08;encoding&#xff09;&…

【随笔】Git 实战篇 -- Git Rebase出错?手把手教你如何优雅地解决常见问题 (四十二)

&#x1f48c; 所属专栏&#xff1a;【Git】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#x1f496; 欢迎大…

JAVA系列:NIO

NIO学习 一、前言 先来看一下NIO的工作流程图&#xff1a; NIO三大核心组件&#xff0c;channel&#xff08;通道&#xff09;、Buffer&#xff08;缓冲区&#xff09;、selector&#xff08;选择器&#xff09;。NIO利用的是多路复用模型&#xff0c;一个线程处理多个IO的读…

探秘三相交流电子负载应用

三相交流电子负载是模拟实际负载的电子设备&#xff0c;主要用于电源、电机、变压器等产品的性能测试和老化试验。它能够精确控制电流、电压、频率等参数&#xff0c;模拟各种复杂的负载情况&#xff0c;为产品研发和质量控制提供可靠的测试手段。 三相交流电子负载在电源产品测…

#经验分享#笔记

一闪论文是一款专门用于论文写作、查重和降重的工具&#xff0c;被广泛认为是非常好用的。它可以帮助学生和研究者们更高效地撰写论文&#xff0c;并且确保内容的原创性。 首先&#xff0c;一闪论文具有强大的查重和降重功能。它可以快速准确地检测论文中的相似内容&#xff0…

4. 排序算法

文章目录 1.简单排序1.1 冒泡排序1.1.1 步骤核心思想1.1.2 参考代码1.1.3 时间复杂度1.1.4 空间复杂度1.1.5 优化 1. 2. 选择排序1.2.1 核心思想1.2.2 步骤1.2.3 参考代码1.2.4 时间复杂度1.2.5 空间复杂度1.2.6 优化 1.3 插入排序1.3.1 思想1.3.2 步骤1.3.3 参考代码1.3.4 时间…

JavaScript中的const关键字解析

在JavaScript中&#xff0c;const关键字用于声明常量&#xff0c;即那些一旦赋值后就不应更改的变量。它在许多方面与let关键字类似&#xff0c;但增加了一个重要的约束条件——必须在声明时初始化&#xff0c;并且之后尝试修改其值会导致错误。下面将深入探讨const的特性及其使…

js使用链表实现音乐播放器(新增,下一首播放,置顶,删除)

什么是链表 链表是一种线性数据结构&#xff0c;与数组类似&#xff0c;它用于存储一系列元素。不过&#xff0c;与数组在内存中连续存储元素不同&#xff0c;链表中的元素&#xff08;称为节点&#xff09;在内存中可以是非连续存放的。每个节点包含两部分&#xff1a;一部分…

Content-Type ‘application/x-www-form-urlencoded;charset=UTF-8‘ is not supported

前端向后端发送数据时候出现了这个问题&#xff0c;发现是内容类型的错误。浏览器的form表单默认 content-type类型为application/x-www-form-urlencoded &#xff1a; <form encType””>中默认的encType&#xff0c;form表单数据被编码为key/value格式发送到服务器&…

proxmox重装后挂载分区

主要是需要备份/etc/pve/storage.cfg storage dir: local path /var/lib/vzcontent vztmpl,iso,backup,imagesshared 0lvmthin: data1 thinpool data1vgname data1content images,rootdirnodes pve232,pve233,pve1dir: hdd1 path /mnt/pve/hdd1content rootdir,snippets,vztm…

Java开发的saas模式智能制造超强云MES系统源码springboot+mysql+uniapp一整套云MES系统源码

Java开发的saas模式智能制造超强云MES系统源码springbootmysqluniapp一整套云MES系统源码 智能制造超强云MES系统概述&#xff1a; MES以生产车间管理为核心&#xff0c;帮助企业实现生产动态监控和管理。把制造数据管理、计划排程管理、生产调度管理、库存管理、质量管理、人…

python小甲鱼作业001-3讲

0.Python是什么类型的语言 编译型语言不同&#xff0c;Python 代码在执行时由解释器直接逐行解释执行&#xff0c;无需先编译成机器语言。这使得开发过程更快&#xff0c;因为你可以即时运行并测试你的代码。 Python 在运行时自动推断变量的类型&#xff0c;无需在代码中显式声…

swagger-ui页面接口的入参出参与代码实体类不一致有差异、swagger请求实体与预期定义不符、swagger参数与实体中参数不一致原因分析

文章目录 一、问题背景二、问题原因及解决方法 一、问题背景 项目集成swagger之后&#xff0c;发现有个接口的请求跟接口对应不上&#xff0c;把其他接口的请求参数放到当前这个请求上了。 如下图&#xff1a;test1接口的请求参数是其他请求的&#xff0c;并不是test1接口的 …

win10如何查看本机ip地址?三招搞定,快来试试吧

在数字化时代&#xff0c;IP地址作为网络设备的唯一标识&#xff0c;对于计算机使用者来说具有重要意义。无论是为了进行网络设置、远程连接&#xff0c;还是解决网络问题&#xff0c;了解如何查看本机IP地址都是一项必备技能。对于使用Windows 10操作系统的用户来说&#xff0…

简单的 Cython 示例

1&#xff0c; pyx文件 fibonacci.pyx def fibonacci_old(n):if n < 0:return 0elif n 1:return 1else:return fibonacci_old(n-1) fibonacci_old(n-2) 2&#xff0c;setup.py setup.py from setuptools import setup from Cython.Build import cythonizesetup(ext_mod…