springboot缓存

在进入缓存之前先了解几个概念:

cacheable的用法:

下面举例说明:缓存写在service层我们直接看service

/**
 *将方法的运行结果进行储存以后要相同的数据,直接从缓存中取
 * CacheManager管理多个组件的,对缓存的真正crud的操作,在cach组件中,每一个缓存组件有自己的名字:
 * 几个属性:
 *          cacheNames/values:指定缓存组的名字;将方法的返回值放在哪个缓存中,是数组的形式,可以指定多个缓存
 *          key:缓存数据使用的key;可以用他来指定,默认是使用方法的值
 *              编写spel:#id;参数id的值 #a0 #p0 #root.args[0]
 *          keyGenerator :key的生成器;可以自己指定key的生成器的组件id
 *              key/keyGenerator:二者选一个
 *          CasheManager :指定缓存管理器;或者cacheResolver指定获取解析器
 *          condition:指定符合条件的情况下才缓存
 *                      ,condition = "#a0>1"第一个参数的值>0进行缓存。也可用后边的写法(编写spel:#id;参数id的值 #a0 #p0 #root.args[0])
 *          unless:否定缓存;当unless指定的条件为true,方法的返回值就不会被缓存,可以获取到结果进行判断
 *                  unless="#result==null"
 *                  unless = "#ao==2",如果第一个参数是2号就不缓存
 *          sync:是否异步
 *                  不支持unless属性
 *
 *
 * @param id
 * @return
 */
@Cacheable(cacheNames = {"emp"}/*,keyGenerator = "mykeyGenerator",condition = "#a0>1",unless = "#ao==2"*/)
public Employee getEmp(Integer id) {
    System.out.println("查询"+id+"员工号");
    Employee employee =employeeMapper.getEmpById(id);
    return employee;
}

上为cachabl的用法,一般在用于查询方法上。:

CacheManager管理多个组件的,对缓存的真正crud的操作,在cach组件中,每一个缓存组件有自己的名字: * 几个属性: * cacheNames/values:指定缓存组的名字;将方法的返回值放在哪个缓存中,是数组的形式,可以指定多个缓存 * key:缓存数据使用的key;可以用他来指定,默认是使用方法的值 * 编写spel:#id;参数id的值 #a0 #p0 #root.args[0] * keyGenerator :key的生成器;可以自己指定key的生成器的组件id * key/keyGenerator:二者选一个 * CasheManager :指定缓存管理器;或者cacheResolver指定获取解析器 * condition:指定符合条件的情况下才缓存 * ,condition = "#a0>1"第一个参数的值>0进行缓存。也可用后边的写法(编写spel:#id;参数id的值 #a0 #p0 #root.args[0]) * unless:否定缓存;当unless指定的条件为true,方法的返回值就不会被缓存,可以获取到结果进行判断 * unless="#result==null" * unless = "#ao==2",如果第一个参数是2号就不缓存 * sync:是否异步 * 不支持unless属性。

下面看cachinput的用法,该注解主要用于方法上将更新的值,更新到缓存中,注意,他的key一定要与cacheable的相同:

/**
 * @CachePut;即调用方法,又更新缓存
 * 修改了数据库的某个数据,同时更新缓存
 * 运行实际先调用目标方法,然后将目标方法的结果缓存起来
 * 注意:如果默认不写的话,更新过后的数据不会写到缓存中。
 *         key="#employee.id":使用传入的参数的员工的id
 *         key="#result.id"使用返回后的id
 *              @Cacheable的key是不能用#result因为该注解是先要获取缓存中的key
 *    取缓存的key要与放缓存的key一样
 */
@CachePut(value = "emp",key = "#employee.id")
public Employee updateEmp(Employee employee){
    System.out.println("updateEmp被调用*******"+employee);
    employeeMapper.updataEmp(employee);
    return employee;
}

这就是一个简单缓存的例子。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值