开发实践三级分类树


前言

提示:这里可以添加本文要记录的大概内容:

在日常实际开发中,常常用到分类信息,这里介绍一种构建自关联的三级分类。我们数据库中的category表也使用自关联实现了三级分类,一级类别父类别id为0,如下图:
在这里插入图片描述


提示:以下是本篇文章正文内容,下面案例可供参考

一、分类功能实现逻辑

我们数据库mall_pms的category表使用自关联实现了三级分类

当前项目使用固定的三级分类

1.从数据库中查询出所有分类信息,一次性全查

2.构建分类信息的父子结构,实现查询返回父子结构的分类信息

3.将查询到的结果保存在Redis中,以备后续用户直接获取

代码中要判断Redis中是否包含全部分类数据,不包含的话做上面操作

包含分类数据的话直接获得之后返回

二、业务分析

查询全部分类的业务重点在构建三级分类树结构

我们需要将从数据库中查询出的分类对象构成下面的结构

[
    {
   id:1,name:"手机/运行商/数码",parentId:0,depth:1,children:[
        {
   id:2,name:"手机通讯",parentId:1,depth:2,children:[
            {
   id:3,name:"智能手机",parentId:2,depth:3,children:null},
            {
   id:4,name:"非智能手机",parentId:2,depth:3,children:null}
        ]}
    ]},
    {
   id:5,name:"电脑/办公",parentId:0,depth:1,children:[....]}
]

上面是我们需要获得的对象的结构

可以理解为下图
在这里插入图片描述
在数据库mall_pms中

有pms_category表,这个表就是保存全部分类信息的表格,见上图。

三、实施开发

1. 构建前台分类树封装分类实体

@Data
@ApiModel(value="商品分类树实体")
public class FrontCategoryEntity implements Serializable {
   
    private static final long serialVersionUID = 1L;

    /**
     * 类别id®
     */
    @ApiModelProperty(value = "类别id")
    private Long id;

    /**
     * 类别名称
     */
    @ApiModelProperty(value = "类别名称")
    private String name;
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值