文章目录
前言
提示:这里可以添加本文要记录的大概内容:
在日常实际开发中,常常用到分类信息,这里介绍一种构建自关联的三级分类。我们数据库中的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;