java树化省市区等

一.在实际业务中常常需要将多级数据树化,传递给前端。

递归:资源消耗过大
steam流:需要多次手动设置foreach
stack:简单明了,消耗小,利用他的弹栈优点,不管树有多深都可以设置

二.省市区表

在这里插入图片描述

三.准备

(1)实体
在这里插入图片描述

(2)vo实体
在这里插入图片描述

四.stack方式

service业务代码
在这里插入图片描述

 /**
     * 所有查询地区
     */
    @Override
    public List<AreaVo> selectAll() {
        //1.查询地区
        List<Area> list = this.list(null);
        List<AreaVo> allList = list.stream().map(item -> {
            AreaVo areaVo = new AreaVo();
            areaVo.setId(item.getId());
            areaVo.setPid(item.getPid());
            areaVo.setLabel(item.getAdcode());
            areaVo.setValue(item.getName());
            return areaVo;
        }).collect(Collectors.toList());
        //2.获取省
        List<AreaVo> provinceList = allList.stream().filter(item -> item.getPid() == 0).collect(Collectors.toList());

        List<AreaVo> areaVos = buildTreeByStack(allList, provinceList);

        return areaVos;
    }

    public List<AreaVo> buildTreeByStack(List<AreaVo> treeNodes, List<AreaVo> parentNodes){
        Stack<AreaVo> stack= new Stack<>();
        //根入栈
        parentNodes.forEach(e->stack.push(e));

        List<AreaVo> root=new ArrayList<>();
        while (!stack.isEmpty()){
            AreaVo currentRoot = stack.pop();
            List<AreaVo> children=new ArrayList<>();
            
            Iterator<AreaVo> iterator = treeNodes.iterator();
            while (iterator.hasNext()){
                AreaVo next = iterator.next();
                if(currentRoot.getId().toString().equals(next.getPid().toString())){
                    children.add(next);
                    iterator.remove();
                }
            }

            currentRoot.setChildren(children);
            if(!children.isEmpty()){
                //子节点不为空入栈
                children.forEach(e->stack.push(e));
            }
            if (currentRoot.getPid()==0){
                root.add(currentRoot);
            }
        }
        return root;
    }

(4)结果
在这里插入图片描述

五.steam流

    /**
     * 所有查询地区
     */
    @Override
    public List<AreaVo> selectAll() {
        String key = RedisConstants.COMMON_AREA;
        //1.先去redis中取
        List<AreaVo> areaList = redisCache.getCacheObject(key);
        if (CollUtil.isNotEmpty(areaList)) {
            return areaList;
        }

        List<AreaVo> tree = CollUtil.newLinkedList();
        //1.查询地区
        List<AreaVo> list = areaMapper.findAll();
        Map<Long, List<AreaVo>> map = list.stream().collect(Collectors.groupingBy(AreaVo::getPid));
        //得到省
        list.stream().filter(vo -> vo.getPid() != null && vo.getPid() == 0).forEach(province -> {
            List<AreaVo> cityList = map.get(province.getId());
            if (CollUtil.isNotEmpty(cityList)) {
            	//市设置区
                cityList.forEach(city -> city.setChildren(map.get(city.getId())));
            }
            province.setChildren(cityList);
            //省设置市
            tree.add(province);
        });
        if (CollUtil.isNotEmpty(tree)) {
            redisCache.setCacheObject(key, tree);
        }
        return tree;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

愛沢かりん

感谢您对我的支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值