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
相关推荐
chuanauc5 分钟前
Kubernets K8s 学习一头生产的驴22 分钟前
java整合itext pdf实现自定义PDF文件格式导出YuTaoShao28 分钟前
【LeetCode 热题 100】73. 矩阵置零——(解法二)空间复杂度 O(1)zzywxc78732 分钟前
AI 正在深度重构软件开发的底层逻辑和全生命周期,从技术演进、流程重构和未来趋势三个维度进行系统性分析YuTaoShao3 小时前
【LeetCode 热题 100】56. 合并区间——排序+遍历程序员张33 小时前
SpringBoot计时一次请求耗时llwszx6 小时前
深入理解Java锁原理(一):偏向锁的设计原理与性能优化芳草萋萋鹦鹉洲哦6 小时前
【vue3+tauri+rust】如何实现下载文件mac+windows李洋-蛟龙腾飞公司6 小时前
HarmonyOS NEXT应用元服务常见列表操作多类型列表项场景云泽野6 小时前
【Java|集合类】list遍历的6种方式