Java 递归查询该部门,及其下属部门,所有用户:
Set<User> userSet 作为传入参数,并将其作为返回值, 随着递归查询,执行 userSet.addAll(users); userSet 逐渐被添加。
public Set<User> queryDeptByParentDept(String departmentId,Set<User> userSet){
//根据所选择的部门id--selectDepartment,获取Department对象
Department selectDepartment = departmentDao.findOne(departmentId);
//获取该部门中的所有用户
Set<User> users = selectDepartment.getUsers();
//将获得的所有用户,添加到userSet中
userSet.addAll(users);
//如果该部门有子部门,获取子部门,查询该子部门中的所有用户,
//并传入userSet,将查询结果,存入到userSet中,将其返回
if (selectDepartment.getChildrenDepartment().size() > 0) {
Set<Department> childrenDepartments = selectDepartment.getChildrenDepartment();
if (childrenDepartments != null && !childrenDepartments.isEmpty()) {
for (Department dep : childrenDepartments) {
queryDeptByParentDept(dep.getId(),userSet);
}
}
}
return userSet;
}
调用方法:
//查询该部门,及其下属部门,所有用户
Set<User> userSet=new HashSet<>();
//传入一个空的userSet,将查询的结果集合userSet返回
Set<User> users = queryDeptByParentDept(department,userSet);
if (users != null && !users.isEmpty()) {
for (User user : users) {
String applyUserName = user.getName();
System.out.println(applyUserName);
}
}