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
相关推荐
only-qi1 小时前
146. LRU 缓存xuxie132 小时前
SpringBoot文件下载(多文件以zip形式,单文件格式不变)bantinghy2 小时前
Linux系统TCP/IP网络参数优化星期天要睡觉2 小时前
Linux 综合练习重生成为编程大王2 小时前
Java中的多态有什么用?666和7772 小时前
Struts2 工作总结saynaihe2 小时前
proxmox8升级到proxmox9中草药z2 小时前
【Stream API】高效简化集合处理野犬寒鸦3 小时前
力扣hot100:搜索二维矩阵 II(常见误区与高效解法详解)(240)Orchestrator_me3 小时前
CentOS交换区处理