day03上-无限菜单与redis

这篇博客介绍了如何在商品分类查询中实现无限菜单功能,通过自定义ResultMap并递归查询实现。同时,文章探讨了使用Redis进行缓存优化的步骤,包括引入依赖、配置属性、序列化策略的调整,以提升系统查询效率。
摘要由CSDN通过智能技术生成

查询任意菜单以及其子菜单

因为是商品种类,所以要在商品分类查询那个类里实现这个功能

 

然后在接口里声明该方法,去实现类里实现该方法,这里传入的是参数就是当前菜单的id,要查询的是当前菜单和他的所有子菜单

因为像这种复杂查询mybatis-plus本身是实现不了的,所以需要我们自己去写这个方法。

 

首先是做好映射,即把数据库中的表数据和java类的属性做好映射。然后一般情况下下面的那个select查询就能实现功能,不过,这里的select还不够,因为这个select只能实现查询当前id的商品种类,无法做到查询子菜单,所以我们再弄一个resultMap也就是ExtendResultMap,他继承自第一个ResultMap,有第一个的所有属性,并且,还有了另一个属性,chidren,也就是这个

 然后开始说这个的含义,说之前先看看数据库里的parent_id是什么?

如图,我们要实现的就是加入传入的参数是0,那么查询所有分类,如果传入的参数是2,那么只是2级菜单和他的子菜单也就是19

好了,开始说刚刚的xml中的那串代码的含义

首先,前端传来请求进入Controller,调用对应方法。

于是进入这个的实现类

这个方法在mapper中创建,去xml中实现

于是我们最后其实就是进入到了xml,执行的这里的sql语句,也就是listCatelogWithChidren语句,查询出来的结果如下:

重点来了,这个sql语句的返回值是ExtendResultMap,也就是说会将查询到的结果封装成ExtendResultMap,然后这个ExtendResultMap中又有一个chidren属性,chidren被声明为一个集合。后面又有一个select,也就是说对chidren中的每一个元素都执行后面的select sql语句,也就是又执行listCatelogWithChildren方法,传入成参数值就是id,假如这里的id为1,那么优惠查到下列的结果

以此类推,就会把该菜单的所有子菜单也给查出来,也就是说,这里使用了递归来实现该功能!!!也就是说把这一次的结果的id作为下一次查询的parent_id,直到查询不到结果。通过这个就能实现无限子菜单

 

还有个要重点注意的是:mapper文件必须放入配置文件内,也就是resources里面,这样才能被识别到,不然java是找不到的。也就是放在这儿

然后写好配置文件

 

分类以及子类菜单实现

 

接下来就是优化了,加入每一次都要这样重新查询的话,其实挺浪费时间和资源的,所以这里就可以开始使用缓存啦

缓存的使用场景:

一些固定的数据,不太变化是时候,高频访问的数据(基本不变),变化频率低的都可以放入缓存,加速系统的访问速度。缓存的目的就是提高系统查询效率,提供性能

开始优化(也就是使用redis实现缓存)

整合redis步骤

1)导入starter-data-redis

2)application.properties中配置与spring.redis相关的属性

不仅是redis,以后引入某个功能,可能都还有XXXAutoConfiguration类,在这个类中会在XXXProperties中说明了(prefix="spring.redis")就是使用哪种前缀进行配置

比如这里,首先引入redis依赖

 

 

先装redis,还是通过docker方式安装redis的镜像

 

 

 

redis操作成功了

redis中也能找到(假如是存的对象,会被序列化为二进制字节流)

不过如果被序列化,这里的以后也只有java能够读取,假如是其他语言可能访问不了该redis数据,也就是说这种方式的序列化不是跨语言的,那么什么是跨语言的呢?我们可以转换成json字符串

进入redisTemplate源码可以看到,这里的默认序列化器是jdk的

于是我们可以通过更改默认序列化器来达到序列化成json数据也就可以被其他语言也接收了,我们只需要创建自己满意的序列化器就可以了

 

这里可以看到注解@ConditionOnMissingBean,也就是说如果没有自己实现这个bean,那么redis就会默认使用这个bean,所以我们得自己去实现

 我这里自己设置了序列化器GenericJackson2JsonRedisSerializer()

这里存储的就是json格式的字符串了,大功告成

 

测试通过,开始正式的使用redis

加上缓存的代码如下:

然后我们刷新主页面,发现输出了这句话,说明缓存成功

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值