✅P45_三级分类-查询-递归树形结构获取

gong_yz大约 1 分钟谷粒商城

实体类修改

@Data
@TableName("pms_category")
public class CategoryEntity implements Serializable {
    private static final long serialVersionUID = 1L;
    /**
     * 分类id
     */
    @TableId
    private Long catId;
    /**
     * 分类名称
     */
    private String name;
    /**
     * 父分类id
     */
    private Long parentCid;
    /**
     * 层级
     */
    private Integer catLevel;
    /**
     * 是否显示[0-不显示,1显示]
     */
    @TableLogic(value = "1", delval = "0")
    private Integer showStatus;
    /**
     * 排序
     */
    private Integer sort;
    /**
     * 图标地址
     */
    private String icon;
    /**
     * 计量单位
     */
    private String productUnit;
    /**
     * 商品数量
     */
    private Integer productCount;

    @JsonInclude(JsonInclude.Include.NON_EMPTY)
    @TableField(exist = false) //表示这个属性在表中是不存在的
    private List<CategoryEntity> children;
}

三级分类递归数据接口实现

返回格式为树形结构

public List<CategoryEntity> listWithTree() {
    //1、查出所有分类
    List<CategoryEntity> entities = baseMapper.selectList(null);

    //2、组装成父子的树形结构
    //2.1)、找到所有的一级分类,给children设置子分类
    return entities.stream()
        // 过滤找出一级分类
        .filter(categoryEntity -> categoryEntity.getParentCid() == 0)
        // 处理,给一级菜单递归设置子菜单
        .peek(menu -> menu.setChildren(getChildless(menu, entities)))
        // 按sort属性排序
        .sorted(Comparator.comparingInt(menu -> (menu.getSort() == null ? 0 : menu.getSort())))
        .collect(Collectors.toList());
}

/**
 * 递归查找所有菜单的子菜单
 */
private List<CategoryEntity> getChildless(CategoryEntity root, List<CategoryEntity> all) {
    return all.stream()
        .filter(categoryEntity -> categoryEntity.getParentCid().equals(root.getCatId()))
        .peek(categoryEntity -> {
            // 找到子菜单
            categoryEntity.setChildren(getChildless(categoryEntity, all));
        })
        .sorted(Comparator.comparingInt(menu -> (menu.getSort() == null ? 0 : menu.getSort())))
        .collect(Collectors.toList());
}