private List<Long> getJuniorDeptIds(R<List<SysUser>> userList, List<Long> xiajiId) {
List<Long> userIds = new ArrayList<>();
// 创建一个临时列表,用于存储当前层级的下级部门id
List<Long> currentLevelDeptIds = new ArrayList<>(xiajiId);
// 直到没有下级部门为止
while (!currentLevelDeptIds.isEmpty()) {
List<Long> nextLevelDeptIds = new ArrayList<>();
// 遍历当前层级的下级部门id
for (Long deptId : currentLevelDeptIds) {
for (SysUser datum : userList.getData()) {
if (Objects.equals(datum.getDeptId(), deptId)) {
userIds.add(datum.getUserId());
// 将当前部门的所有下级部门id添加到下一层级列表中
nextLevelDeptIds.add(datum.getUserId());
}
}
}
// 更新当前层级的下级部门id为下一层级的部门id
currentLevelDeptIds = nextLevelDeptIds;
}
return userIds;
}
java通过用户id寻找下级
youmdt2023-09-11 10:32
相关推荐
ErizJ1 分钟前
面试 | LinuxxcLeigh4 分钟前
复杂 SQL 过滤时机过晚?金仓基于代价的连接条件下推方案来了星轨zb4 分钟前
非遗AI对话系统架构升级实战iPadiPhone5 分钟前
Spring Boot 核心注解全维度解析与面试复盘菜_小_白10 分钟前
高并发定时任务调度系统HAPPY酷14 分钟前
Linux 网络命令速查:告别 `ifconfig`,拥抱 `ip`筱璦16 分钟前
期货软件开发 - 交易报表青衫客3618 分钟前
浅谈 Apache POI:XSSFWorkbook 的原理与实践(Java 操作 Excel 实践指南)沙雕不是雕又菜又爱玩18 分钟前
基于springboot的超市收银系统SunnyDays101119 分钟前
使用 Java 高效删除 Excel 空白行与空白列