From 18ebe42d5e0b80c39c399090fbb8487559c4b99f Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期六, 11 十月 2025 18:23:19 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TDeptServiceImpl.java | 20 ++++++++++++++++++++
1 files changed, 20 insertions(+), 0 deletions(-)
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TDeptServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TDeptServiceImpl.java
index 035deb8..62a6894 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TDeptServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TDeptServiceImpl.java
@@ -1,5 +1,6 @@
package com.ruoyi.system.service.impl;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.common.basic.PageInfo;
import com.ruoyi.common.core.domain.entity.TDept;
@@ -7,6 +8,7 @@
import com.ruoyi.system.service.TDeptService;
import org.springframework.stereotype.Service;
+import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
@@ -32,6 +34,24 @@
return buildDeptTree(depts);
}
+ @Override
+ public List<Integer> getAllSubDeptIds(String deptId) {
+ List<Integer> allSubIds = new ArrayList<>();
+ getSubDeptIdsRecursive(Integer.valueOf(deptId), allSubIds);
+ return allSubIds.stream().distinct().collect(Collectors.toList());
+ }
+ private void getSubDeptIdsRecursive(Integer parentId, List<Integer> allSubIds) {
+ // 查询直接下级
+ List<Integer> directSubIds = this.baseMapper.selectList(new LambdaQueryWrapper<TDept>().eq(TDept::getParentId, parentId)).stream()
+ .map(TDept::getId).collect(Collectors.toList());
+ for (Integer subId : directSubIds) {
+ allSubIds.add(subId);
+ // 递归查询下级的下级
+ getSubDeptIdsRecursive(subId, allSubIds);
+ }
+ allSubIds.add(Integer.valueOf(parentId));
+
+ }
/**
* 构建部门树结构
* @param depts 部门列表
--
Gitblit v1.7.1