使用Java Stream API获取子部门的所有父级部门

使用Java Stream API获取子部门的所有父级部门

过了腊八就是年
车票
订了吗?想家了吧.....

在数据库表中,经常会有包含层次结构的部门信息表。本博客将使用Java语言和Stream API演示如何获取给定子部门的所有父级部门,并在代码中加入详细注释。

1. 创建 Department 类

首先,我们需要定义一个类来表示部门信息。Department类包含三个属性:idnameparentId,分别表示部门的唯一标识、名称和父级部门的标识。

java 复制代码
public class Department {
    private long id;
    private String name;
    private long parentId;

    // 构造函数
    public Department(long id, String name, long parentId) {
        this.id = id;
        this.name = name;
        this.parentId = parentId;
    }

    // Getter和Setter方法省略
}

2. 编写 DepartmentUtils 类

接下来,我们创建一个DepartmentUtils类,其中包含一个静态方法getParentDepartments,该方法使用递归调用来获取给定子部门的所有父级部门。注释将详细解释每个关键步骤。

java 复制代码
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.stream.Collectors;
import java.util.stream.Stream;

public class DepartmentUtils {

    /**
     * 获取给定子部门的所有父级部门
     *
     * @param allDepartments 包含所有部门信息的列表
     * @param childDepartmentId 给定子部门的ID
     * @return 包含所有父级部门的列表
     */
    public static List<Department> getParentDepartments(List<Department> allDepartments, long childDepartmentId) {
        // 使用递归调用获取所有父级部门
        return getParentDepartmentsRecursively(allDepartments, childDepartmentId)
                .stream()
                .filter(Objects::nonNull)
                .collect(Collectors.toList());
    }

    /**
     * 递归方法:获取给定子部门的所有父级部门
     *
     * @param allDepartments 包含所有部门信息的列表
     * @param childDepartmentId 给定子部门的ID
     * @return 包含所有父级部门的列表
     */
    private static List<Department> getParentDepartmentsRecursively(List<Department> allDepartments, long childDepartmentId) {
        // 查找给定ID的子部门
        Optional<Department> childDepartment = allDepartments.stream()
                .filter(d -> d.getId() == childDepartmentId)
                .findFirst();

        if (childDepartment.isPresent()) {
            // 查找子部门的父部门
            Department parentDepartment = allDepartments.stream()
                    .filter(d -> Objects.equals(d.getId(), childDepartment.get().getParentId()))
                    .findFirst()
                    .orElse(null);

            if (parentDepartment != null) {
                // 递归调用,获取父部门的所有父级部门
                List<Department> parentDepartments = getParentDepartmentsRecursively(allDepartments, parentDepartment.getId());

                // 合并当前父部门和其所有父级部门
                return Stream.concat(Stream.of(parentDepartment), parentDepartments.stream())
                        .collect(Collectors.toList());
            }
        }

        // 如果子部门或其父部门未找到,返回空列表
        return new ArrayList<>();
    }
}

3. 使用示例

最后,我们创建一个使用示例,演示如何调用DepartmentUtils类来获取子部门的所有父级部门。这个示例包含了一个包含部门信息的列表,并打印了结果。

java 复制代码
import java.util.Arrays;
import java.util.List;

public class Main {
    public static void main(String[] args) {
        // 创建部门信息列表
        List<Department> allDepartments = Arrays.asList(
                new Department(1, "部门A", 0),
                new Department(2, "部门B", 1),
                new Department(3, "部门C", 2),
                // 添加其他部门信息
        );

        // 选择一个子部门的ID进行查询
        long childDepartmentId = 3;

        // 获取子部门的所有父级部门
        List<Department> parentDepartments = DepartmentUtils.getParentDepartments(allDepartments, childDepartmentId);

        // 打印结果
        System.out.println("子部门的所有父级部门:");
        parentDepartments.forEach(department -> System.out.println(department.getName()));
    }
}

4. 避免 NullPointerException

在代码中,我们对可能导致NullPointerException的情况进行了处理,确保在访问属性之前检查了null值。如果子部门或其父部门未找到,我们返回一个空列表而不是null,以避免潜在的异常。

相关推荐
程序员小假几秒前
我们来说一说解决线程安全的方案
后端
李九四7 分钟前
章节16:实现注释功能
后端·架构
_風箏8 分钟前
SpringBoot【集成Thumbnailator】Google开源图片工具缩放+区域裁剪+水印+旋转+保持比例等(保姆级教程含源代码)
spring boot·后端·google
_風箏9 分钟前
SpringBoot【ElasticSearch集成 02】Java HTTP Rest client for ElasticSearch Jest 客户端集成
java·后端·elasticsearch
xiaok10 分钟前
docker拉取镜像太慢,配置国内的镜像加速器
后端
林太白16 分钟前
动态角色权限和动态权限到底API是怎么做的你懂了吗
前端·后端·node.js
野犬寒鸦23 分钟前
力扣hot100:字母异位词分组和最长连续序列(49,128)
java·数据结构·后端·算法·哈希算法
NineData38 分钟前
NineData 最新发布 SQL Server 双向实时同步功能
数据库·后端·架构
IT果果日记40 分钟前
没有Kafka怎么办?Flink SQL 创建 mysql-cdc 作业
大数据·后端·flink
Goboy1 小时前
入坑了,都是2e31惹得锅
后端