查询表中数据,并返回成Tree树形数据,解决办法

本文介绍了如何将查询结果转化为树形数据结构并进行展示。通过创建DTO对象,利用Java的Stream API和Jackson库的@JsonInclude注解进行数据格式化。在代码实现中,首先遍历所有数据,然后根据parentId属性构建树形结构。最后,数据以文科课程和理科课程分类的形式展示。
摘要由CSDN通过智能技术生成


前言

在这里插入图片描述
当需要将以上查询到的数据返回为tree,即树形数据时,如何能快速有效的完成?下面将为你解答。


一、实现步骤:

1.创建DTO,用于格式化数据

@JsonInclude(value = JsonInclude.Include.NON_EMPTY)
  将该标记放在属性上,如果该属性为NULL则不参与序列化
  如果放在类上边,那对这个类的全部属性起作用
  Include.Include.ALWAYS 默认
  Include.NON_DEFAULT 属性为默认值不序列化
  Include.NON_EMPTY 属性为 空(“”) 或者为 NULL 都不序列化
  Include.NON_NULL 属性为NULL 不序列化

	@Data
    @JsonInclude(value = JsonInclude.Include.NON_EMPTY)
    public static class CourceDto {
        private Integer value;
        private String label;
        @JsonIgnore //作用在属性上,生成json时,不生成parentId 属性
        private Integer parentId;
        private List<CourceDto> children = new ArrayList<>();
    }

2.代码实现

代码如下:

	@PostMapping("check-tree-advanced")
    public List<CourceDto> checkRepetitionForTreeAdvanced() throws Exception {
        List<Course> courseList = courseRepo.findAll();

        Map<Integer, CourceDto> map = courseList.stream().collect(Collectors.toMap(Course::getId, e -> {
            CourceDto courceDto = new CourceDto();
            courceDto.setValue(e.getId());
            courceDto.setLabel(e.getName());
            courceDto.setParentId(e.getParentId());
            return courceDto;
        }));
        List<CourceDto> result = new ArrayList<>();
        map.forEach((k, v) -> {
            if (v.getParentId() == null) { // 如果parentId为空,则表述该数据为主目录
                result.add(v);
            } else { // 如果不为空,则找到map中对应的主目录数据,并插入children中
                Integer parentId = v.getParentId();
                CourceDto courceDto = map.get(parentId);
                if (courceDto != null) {
                    courceDto.getChildren().add(v);
                }
            }
        });
        return result;
    }

3.结果展示

数据将按照文科课程与理科课程进行分类:
在这里插入图片描述


SQL查询树形结构的数据时,我们通常会使用递归查询来实现。在 MyBatis 中,我们可以通过自定义结果映射器和嵌套查询语句来将递归查询的结果映射树形结构数据。 以下是一个示例 SQL 查询语句: ``` WITH RECURSIVE tree AS ( SELECT id, parent_id, name, 0 AS depth FROM my_table WHERE parent_id IS NULL UNION ALL SELECT t.id, t.parent_id, t.name, tree.depth + 1 FROM my_table t JOIN tree ON t.parent_id = tree.id ) SELECT * FROM tree; ``` 这个 SQL 查询语句会查询出一张名为 `my_table` 的树形结构表中所有节点的数据,并按照深度优先的顺序展开。每个节点都会包含其自身的 ID、父节点的 ID、名称和深度。 接下来,我们可以在 MyBatis 中创建一个对应的结果映射器,用来将查询结果映射树形结构数据。这个结果映射器可以使用嵌套查询语句来递归查询每个节点的子节点,然后将它们存储到一个 List 中。 以下是一个示例结果映射器: ``` <resultMap id="treeMap" type="Tree"> <id property="id" column="id"/> <result property="name" column="name"/> <collection property="children" ofType="Tree"> <id property="id" column="id"/> <result property="name" column="name"/> <collection property="children" ofType="Tree" select="getChildren"/> </collection> </resultMap> <select id="getTree" resultMap="treeMap"> WITH RECURSIVE tree AS ( SELECT id, parent_id, name, 0 AS depth FROM my_table WHERE parent_id IS NULL UNION ALL SELECT t.id, t.parent_id, t.name, tree.depth + 1 FROM my_table t JOIN tree ON t.parent_id = tree.id ) SELECT * FROM tree; </select> <select id="getChildren" resultMap="treeMap"> SELECT id, name FROM my_table WHERE parent_id = #{id} </select> ``` 在这个结果映射器中,我们定义了一个名为 `treeMap` 的 resultMap,用来将查询结果映射一个 Tree 对象。这个 Tree 对象包含一个 ID、名称和一个 children 属性,用来存储其子节点。 children 属性使用了一个嵌套查询语句 `getChildren`,用来查询当前节点的子节点。这个嵌套查询语句会使用当前节点的 ID 作为参数,并返回一个包含子节点信息的 List。我们可以使用 ofType 属性来指定 List 中存储的对象类型为 Tree。 最后,在主查询语句中,我们使用 `resultMap="treeMap"` 来指定结果映射器。这个查询语句会递归查询所有节点的信息,并将它们映射一个 Tree 对象。 这样,我们就可以使用 MyBatis 将 SQL 查询结果映射树形结构数据了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值