当前位置:   article > 正文

如何实现商品二级分类_mysql定义商品二级分类

mysql定义商品二级分类

如何实现商品二级分类

首先必须需要id,parent_id字段,其他根据需求扩展。

1.新建Category实体类

  1. public class Category {
  2.    private Long id;
  3.    private Long parent;
  4.    private String name;
  5.    private int sort;
  6.    private String photoUrl;
  7.    private int state;
  8.    private LocalDateTime startTime;
  9.    public Long getId() {
  10.        return id;
  11.   }
  12.    public void setId(Long id) {
  13.        this.id = id;
  14.   }
  15.    public Long getParent() {
  16.        return parent;
  17.   }
  18.    public void setParent(Long parent) {
  19.        this.parent = parent;
  20.   }
  21.    public String getName() {
  22.        return name;
  23.   }
  24.    public void setName(String name) {
  25.        this.name = name;
  26.   }
  27.    public int getSort() {
  28.        return sort;
  29.   }
  30.    public void setSort(int sort) {
  31.        this.sort = sort;
  32.   }
  33.    public String getPhotoUrl() {
  34.        return photoUrl;
  35.   }
  36.    public void setPhotoUrl(String photoUrl) {
  37.        this.photoUrl = photoUrl;
  38.   }
  39.    public int getState() {
  40.        return state;
  41.   }
  42.    public void setState(int state) {
  43.        this.state = state;
  44.   }
  45.    public LocalDateTime getStartTime() {
  46.        return startTime;
  47.   }
  48.    public void setStartTime(LocalDateTime startTime) {
  49.        this.startTime = startTime;
  50.   }
  51. }

2.创建数据库表sp_category

  1. #分类
  2. drop table if exists `sp_category` ;
  3. create table `sp_category` (
  4.                               `id` bigint not null comment 'id',
  5.                               `parent` bigint not null default 0 comment '父id',
  6.                               `name` varchar(50) not null comment  '名称',
  7.                               `sort` int comment '分类顺序',
  8.                               `photo_url` varchar(50) comment '分类图片',
  9.                               `state` int comment '状态',
  10.                               `start_time` datetime comment '创建时间',
  11.          
  12.                               primary key (`id`)
  13. ) engine =innodb default  charset=utf8mb4 comment='分类';

3.通过父id和子id使他们联系在一起,若商品分类为一级目录,没有父目录,则父id为0 ,若为二级目录,则父id指向一级目录的id

4.若要实现tree树形结构,可以选择前端处理或者后端处理,后端处理有多种方式,我这里选择使用的是使用hutool工具实现树形结构。

5.首先导入hutool工具依赖

  1. <dependency>
  2.    <groupId>cn.hutool</groupId>
  3.    <artifactId>hutool-all</artifactId>
  4.    <version>5.8.15</version>
  5. </dependency>

6.实现tree树形结构

  1. List<CategoryDO> nodeList=categoryMapper.all();//这里指从数据库获取的数据
  2. List<Tree<Long>> trees = treeUtil(nodeList);
  1. private List<Tree<Long>> treeUtil(List<CategoryDO> nodeList){
  2.    //配置 这里根据自己需求设置
  3.    TreeNodeConfig treeNodeConfig = new TreeNodeConfig();
  4.    treeNodeConfig.setIdKey("id");
  5.    treeNodeConfig.setParentIdKey("parent");
  6.    treeNodeConfig.setNameKey("name");
  7.    //商品分类权重
  8.    treeNodeConfig.setWeightKey("sort");
  9.    //这里设置递归深度
  10.    treeNodeConfig.setDeep(2);
  11.   //转换器 注意这里的List<Tree<Long>>,Tree内中的泛型类型根据自己的id类型填写
  12.    List<Tree<Long>> treeNodes = TreeUtil.build(nodeList, 0L, treeNodeConfig,
  13.           (categoryDO, tree) -> {
  14.                //Tree中不存在你类中的属性时候,你可以根据需求使用putExtra扩展
  15.        tree.putExtra("id",categoryDO.getId());
  16.        tree.putExtra("parent",categoryDO.getParent());
  17.        tree.putExtra("name",categoryDO.getName());
  18.        tree.putExtra("sort",categoryDO.getSort());
  19.        tree.putExtra("photoUrl",categoryDO.getPhotoUrl());
  20.        tree.putExtra("startTime",categoryDO.getStartTime());
  21.        tree.put("state",categoryDO.getState());
  22.           });
  23.    return treeNodes;
  24. }

7.实现效果

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/686011
推荐阅读
相关标签
  

闽ICP备14008679号