• JSD-2204-(业务逻辑开发)-开发分类功能-分页查询-Day08


    1.开发分类功能

    1.1数据导入

    在给大家提供的csmall-jsd2203项目的doc文件夹下的sql文件夹中

    有多个sql语句文件

    分别去运行它们,我们可以获得酷鲨商城前台的数据库信息了

    我们每个微服务项目原则上只操作少于一个数据库

    1.2分类功能实现逻辑

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

    当前酷鲨商城项目使用固定的三级分类

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

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

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

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

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

    1.3业务分析

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

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

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

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

    可以理解为下图

    在数据库mall_pms中

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

    id:主键

    name:显示在页面上的分类名称

    parentId:父分类的id 如果是一级分类父分类id为0

    depth:分类深度,当前项目就是3级分类,1\2\3 分别代表它的等级

    keyword:搜索关键字

    sort:排序依据 正常查询时,根据此列进行排序,数字越小越出现在前面(升序)

    icon:图标地址

    enable:是否可用

    isparent:是否为父分类 0 假 1真

    isdisplay:是否显示在导航栏 0不显示 1显示

    随堂更新git地址:

    jtzhanghl/csmall-repo-class

    1.4实施开发

    在csmall-front-webapi项目中开发

    创建service.impl包

    包中编写业务逻辑层实现类 实现IFrontCategoryService

    1. @DubboService
    2. @Service
    3. @Slf4j
    4. public class FrontCategoryServiceImpl implements IFrontCategoryService {
    5. // 开过程中使用Redis的规范:为了降低Redis的Key拼写错误的风险,我们会定义常量使用
    6. public static final String CATEGORY_TREE_KEY="category_tree";
    7. // 当前front模块没有连接数据库的操作,所有数据均来源于Dubbo调用product模块
    8. // 所有要消费product模块具备对应功能的接口
    9. @DubboReference
    10. private IForFrontCategoryService dubboCategoryService;
    11. // 操作Redis的对象
    12. @Autowired
    13. private RedisTemplate redisTemplate;
    14. @Override
    15. public FrontCategoryTreeVO categoryTree() {
    16. // 我们先检查Redis中是否包含已经查询出的三级分类树
    17. if(redisTemplate.hasKey(CATEGORY_TREE_KEY)){
    18. // redis中已经包含了三级分类树,直接获取后返回即可
    19. FrontCategoryTreeVO treeVO=
    20. (FrontCategoryTreeVO)
    21. redisTemplate.boundValueOps(CATEGORY_TREE_KEY).get();
    22. // 千万别忘了返回!
    23. return treeVO;
    24. }
    25. // Redis中没有三级分类树信息,表示当前请求可能是第一次请求
    26. // dubbo调用查询pms数据库所有分类对象的方法
    27. List categoryStandardVOs=
    28. dubboCategoryService.getCategoryList();
    29. // 需要将没有关联关系的分类列表CategoryStandardVO类型
    30. // 转换为具备关联关系的分类树列表FrontCategoryEntity类型
    31. // 自定义一个转换三级分类树的方法,减少当前业务代码的冗余度
    32. FrontCategoryT
  • 相关阅读:
    面试经典150题——Day34
    Biotinyl-εAhx-Amyloid β-Protein (1-42),CAS: 1872440-40-8
    机器学习基础:奇异值分解(SVD)
    Anniversary party(树形dp 基础题)
    从VTI7064与W25Qxx了解SPI通信协议
    数据分析入门导读
    mini-vue 代码块
    Vue插槽和Vue过渡动画
    传感器信息系统中的节能收集研究(Matlab代码实现)
    Veritas Backup Exec v22.2.1193.1605 数据备份恢复软件
  • 原文地址:https://blog.csdn.net/TheNewSystrm/article/details/126591396