递归快速获取机构树型图

一般组织架构都会有层级关系,根部门的parentId一般设置为null或者0等特殊字符,而次级部门及以下的parentId则指向他们父节点的id。

以此为基础,业务上经常会有查询整个组织架构层级关系的需求,返回对象中的children属性用来存储子机构的集合,从而形成树型结构。

这种情况一般使用递归写法,能快速完成需求。

1、获取所有根节点,根节点的集合就是最终返回对象的集合的元素数量size

2、设置根节点的子节点集合。

3、递归设置子节点的子节点集合。

java 复制代码
public R<List<BankBranchInfo>> getBankBranchInfo() {

        String sql = "select ORG_ID, ORG_NAME, PARENT_ID from auth_org WHERE TENANT_ID <> 100001 ";
        List<OrgEntity> listAll = beanCruder.selectList(OrgEntity.class, sql);

        List<BankBranchInfo> bankBranchInfos = new ArrayList<>();
        listAll.forEach(org -> {
            BankBranchInfo bankBranchInfo = new BankBranchInfo();
            bankBranchInfo.setId(String.valueOf(org.getOrgId()));
            bankBranchInfo.setBankName(org.getOrgName());
            bankBranchInfo.setParentId(org.getParentId() == null ? null : Long.valueOf(org.getParentId()));
            bankBranchInfos.add(bankBranchInfo);
        });
        //一级
        List<BankBranchInfo> rootList = bankBranchInfos.stream().filter(e -> e.getParentId() == null).collect(Collectors.toList());
        //其他级
        List<BankBranchInfo> other = bankBranchInfos.stream().filter(e -> e.getParentId() != null).collect(Collectors.toList());

        setTree(rootList, other);

        return R.ok(rootList, "查询完成");
    }



private void setTree(List<BankBranchInfo> children, List<BankBranchInfo> other) {
        children.forEach(root -> {
            List<BankBranchInfo> childrenList = new ArrayList<>();
            root.setBankBranchInfos(childrenList);
            //该级子级
            List<BankBranchInfo> temp = other.stream().filter(e -> root.getId().equals(e.getParentId().toString())).collect(Collectors.toList());
            childrenList.addAll(temp);
            if (!childrenList.isEmpty()) {
                setTree(childrenList, other);
            }
        });
    }
相关推荐
IMPYLH几秒前
Linux 的 sync 命令
linux·运维·服务器·python·bash·运维开发
绿草在线7 分钟前
02. JakartaEE11+Thymeleaf实现图书管理模块
java
胡图图不糊涂^_^8 分钟前
网络原理笔记
java·网络·笔记·学习·tcp/ip·http·https
嘻嘻哈哈樱桃10 分钟前
牛客经典101题题解集--哈希
java·数据结构·python·算法·leetcode·职场和发展·哈希算法
SamDeepThinking12 分钟前
秒杀系统里的RocketMQ,不是发个消息那么简单
java·后端·架构
卷毛的技术笔记13 分钟前
告别“盲猜式”排障:分布式链路追踪方案选型与Spring Boot 3实战
java·spring boot·分布式·后端·spring·面试·系统架构
上海云盾安全满满19 分钟前
高防服务器与云防产品都适用哪些情况
运维·服务器
聊点儿技术22 分钟前
广告定向总跑偏?用IP精准定位验证链路是否通畅的排查方法
服务器·网络·代理ip·广告投放·ip精准定位服务·ip地理定位api
遇见火星22 分钟前
离线服务器时间同步NTP服务器配置
服务器·git·github
忡黑梨22 分钟前
eNSP_登录华为设备
运维·服务器·网络·华为·负载均衡