1
luodangjia
2025-01-21 664e75a55c879fbe6eebd9ec488216a6006298a6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package com.ruoyi.system.service.impl;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.system.api.domain.Region;
import com.ruoyi.system.mapper.RegionMapper;
import com.ruoyi.system.service.RegionService;
import org.springframework.stereotype.Service;
import java.util.List;
import java.util.stream.Collectors;
 
@Service
public class RegionServiceImpl extends ServiceImpl<RegionMapper, Region> implements RegionService {
 
    @Override
    public List<Region> getRegionTree() {
        // 查询所有数据
        List<Region> allRegions = list();
 
        // 构建树形结构
        return buildTree(allRegions);
    }
 
    /**
     * 构建树形结构
     *
     * @param allRegions 所有地区数据
     * @return 树形结构数据
     */
    private List<Region> buildTree(List<Region> allRegions) {
        // 1. 找到所有省份(parentId为null或0)
        List<Region> provinces = allRegions.stream()
                .filter(region -> region.getParentId() == null || region.getParentId() == 0)
                .collect(Collectors.toList());
 
        // 2. 递归设置子节点
        provinces.forEach(province -> {
            province.setChildren(getChildren(province, allRegions));
        });
 
        return provinces;
    }
 
    /**
     * 递归获取子节点
     *
     * @param parent     父节点
     * @param allRegions 所有地区数据
     * @return 子节点列表
     */
    private List<Region> getChildren(Region parent, List<Region> allRegions) {
        return allRegions.stream()
                .filter(region -> parent.getId().equals(region.getParentId()))
                .peek(region -> region.setChildren(getChildren(region, allRegions)))
                .collect(Collectors.toList());
    }
}