Spring Cache学习笔记

一.介绍:

 

二.使用:

   2.1导入坐标: 

   2.2如何设置底层使用哪个缓存实现?

      无需单独设置,只要在pom.xml中导入某个缓存方式的坐标,Spring Cache会自动识别使用。 

三.常用注解:

 

四.入门案例学习: 

   4.1主启动类添加@EnableCaching注解,开启缓存注解的功能

//主启动类
@Slf4j
@SpringBootApplication
@EnableCaching//开启缓存注解功能
public class CacheDemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(CacheDemoApplication.class,args);
        log.info("项目启动成功...");
    }
}

   4.2@CachePut使用:在方法上添加该注解,可以将此方法的返回值放到缓存中

(Reids中key的生成:cacheNames代表缓存名称,key是用于动态获得user的主键id) 

//此方法用来保存user对象
    @PostMapping
    //@CachePut(cacheNames = "userCache",key = "#user.id")     //如果使用Spring Cache缓存数据,key的生成:userCache::userId
    //@CachePut(cacheNames = "userCache",key = "#result.id")     //.id的.是对象导航,获取对应里面的内容
    //@CachePut(cacheNames = "userCache",key = "#p0.id")        //获取第一个参数的id
    @CachePut(cacheNames = "userCache",key = "#a0.id")        //获取第一个参数的id
    public User save(@RequestBody User user){
        userMapper.insert(user);
        return user;
    }

 key的填写:#user(从user参数里获取),#result(从返回结果里获取),#root(使用如下图截图所示),#p0(获取第一个参数的id),#a0(获取第一个参数的id)

      4.2.1测试结果: 

         返回结果正常,MySQL和Redis都有值

 

   4.3@Cacheable使用:在方法上添加该注解,可以在该方法执行前先查看缓存中有没有对应的数据,如果有,则直接返回缓存中的数据,如果没有,会执行方法从数据库中查询并将结果保存在缓存中

//此方法可以根据id查询user对象
    @GetMapping
    @Cacheable(cacheNames = "userCache",key = "#id")    //key的生成:userCache::id
    public User getById(Long id){
        User user = userMapper.getById(id);
        return user;
    }

key的填写:

 

      4.3.1测试结果:

         返回结果正常,MySQL和Redis都有值,但控制台显示没有使用sql,说明直接从缓存中查到

 

    4.4@CacheEvict使用:将一条或多条数据从缓存中删除

//此方法可以根据id删除数据
    @DeleteMapping
    @CacheEvict(cacheNames = "userCache",key = "#id")
    public void deleteById(Long id){
        userMapper.deleteById(id);
    }
//此方法可以删除所有数据
    @DeleteMapping("/delAll")
    @CacheEvict(cacheNames = "userCache",allEntries = true)
    public void deleteAll(){
        userMapper.deleteAll();
    }

 

      4.4.1测试结果:

         返回结果200,MySQL和Redis的对应的值都被删除,控制台显示使用了sql

 

 

 

      4.4.2测试结果:

         返回结果200,MySQL和Redis的值都被删除,控制台显示使用了sql

 

 

 

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值