Java 递归查询树形结构

适用于字段parentId存的是上一级,而不是全级的树结构
@Override
    public List<CmsHoliday> getTree(Map<String, Object> paramMap) {
        // 条件查询
        List<CmsHoliday> tree = cmsHolidayMapper.getTree(paramMap);
        // List to Map
        Map<String, CmsHoliday> map = tree.stream().collect(Collectors.toMap(CmsHoliday::getId, Function.identity()));
        // 查询所有
        List<CmsHoliday> all = cmsHolidayService.findAll();
        // 生成树
        List<CmsHoliday> fisheryList = cmsHolidayTree(all, "0",map,(String) paramMap.get("delFlag"));
        return fisheryList;
    }
参数说明如下:
cmsFisheries:查询出来的全部数据
parentId:父级id
tree:符合条件的数据
delFlag:0:上架,1:下架,2:归档
private List<CmsHoliday> cmsHolidayTree( List<CmsHoliday> cmsHolidays, String parentId,Map<String, CmsHoliday> tree,String delFlag){
        if (CollectionUtils.isEmpty(tree)){
            return null;
        }
        // 根据getParentId筛选符合条件的数据
        List<CmsHoliday> fisheryList = cmsHolidays.stream().filter(cmsFishery -> cmsFishery.getParentId().equals(parentId))
                .peek(cmsHoliday -> {
                    // 如果条件中包含父级就把子级也放到List条件中
                    if(tree.containsKey(cmsHoliday.getId()) && cmsHoliday.getDelFlag().equals(delFlag) && !tree.containsKey(cmsHoliday.getParentId())){
                        tree.put(cmsHoliday.getId(), cmsHoliday);
                    }else if (tree.containsKey(cmsHoliday.getParentId()) && cmsHoliday.getDelFlag().equals(delFlag)) {
                        tree.put(cmsHoliday.getId(), cmsHoliday);
                    }
                    // 查询是否有子级
                    List<CmsHoliday> list = this.cmsHolidayTree(cmsHolidays, cmsHoliday.getId(), tree,delFlag);
                    // 判断条件中是否包含自己
                    list = list.stream().filter(c -> tree.containsKey(c.getId())).collect(Collectors.toList());
                    // 如果包含自己就把自己去掉,把父级放到条件中
                    list.forEach(c -> tree.remove(c.getId()));
                    if (!CollectionUtils.isEmpty(list)) {
                        tree.put(cmsHoliday.getId(), cmsHoliday);
                    }
                    cmsHoliday.setChildren(list);
                }).collect(Collectors.toList());
        // 筛选符合条件的父级
        return fisheryList.stream().filter(c -> tree.containsKey(c.getId())).collect(Collectors.toList());
    }

 到这里,递归查询树形结构数据就完成了,生成的树结构形式如下:

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值