java8使用stream流将数据处理成树状结构(非递归)二

该篇博客介绍了如何利用Java8的Stream流处理数据,将章节表和小节表结合,构建非递归的树状结构。通过过滤和映射操作,将两个列表中的数据关联起来,生成包含章节及其对应小节的ChapterVo对象列表。返回的数据格式展示了章节与小节的层级关系。
摘要由CSDN通过智能技术生成

有时需要将数据处理成树形结构,如果数据是一张表内以 id,parentId的形式,可以看看这篇
java8使用stream流将数据处理成树状结构(非递归)

如果数据是两张表A B,B表的parentId对应A表的id这种形式,可以用下面的方法:
章节表 小节表
一个章节可以有多个小节

public List<ChapterVo> getChapterVideoByCourseId() {
   // 章节信息
    List<EduChapter> eduChapterList = eduChapterService.list(null);

    // 小节信息
    List<EduVideo> eduVideoList = eduVideoService.list(null);

    List<ChapterVo> chapterVoList = eduChapterList.stream().map(item1 -> {
        ChapterVo chapterVo = new ChapterVo();
        BeanUtils.copyProperties(item1, chapterVo);
        List<VideoVo> videoVoList = eduVideoList.stream()
                .filter(item2 -> item1.getId().equals(item2.getChapterId()))
                .map(item3 -> {
                    VideoVo videoVo = new VideoVo();
                    BeanUtils.copyProperties(item3, videoVo);
                    return videoVo;
                }).collect(Collectors.toList());
        chapterVo.setChildren(videoVoList);
        return chapterVo;
    }).collect(Collectors.toList());

    return chapterVoList;
}

返回的数据格式:

 "data": 
 [
      {
        "id": "1181729226915577857",
        "title": "第七章:I/O流",
        "children": [
          {
            "id": "1189471423678939138",
            "title": "test",
            "free": null
          },
          {
            "id": "1189476403626409986",
            "title": "22",
            "free": null
          }
        ]
      },
      {
        "id": "15",
        "title": "第一章:Java入门",
        "children": [
          {
            "id": "17",
            "title": "第一节:Java简介",
            "free": null
          },
          {
            "id": "18",
            "title": "第二节:表达式和赋值语句",
            "free": null
          },
          {
            "id": "19",
            "title": "第三节:String类",
            "free": null
          },
          {
            "id": "20",
            "title": "第四节:程序风格",
            "free": null
          }
        ]
      }
]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值