关于spring redis注解实现缓存机制


本文摘自PHP中文网,作者藏色散人,侵删。

下面由Redis教程栏目给大家介绍关于spring redis注解实现缓存机制,希望对需要的朋友有所帮助!

1、xml配置

2、缓存注解@Cacheable、@CacheEvict、@CachePut详解
一、@Cacheable用法详解
1、用在哪里?用在方法或者类上。
2、这两种用法有什么区别?
 用在方法上表示:该方法的返回值将被缓存起来
 用在类上表示:表示该类的所有方法都支持该注解
3、使用后的结果是什么?下次使用相同方法和相同参数调用这个方法的时候将直接从缓存取值,而不需要再次执行该方法。
4、返回值在缓存中怎么存储的?以键值对的方式存储在缓存中,value就是返回值,key由两种策略生成:默认策略和自定义策略
5、默认策略和默认策略怎么用?
  默认策略:在value值后双“::”拼接,形参列表,当形参是对象时,使用json格式:

1

2

3

4

5

6

7

8

9

@CacheConfig(cacheNames="enterprise")//<!-- 声明缓存使用的缓存名称 -->

public interface EnterpriseRepo extends JpaRepository<Enterprise, Integer>,JpaSpecificationExecutor<Enterprise>{

    @Cacheable(value="cash1")

    Enterprise findByid(Integer id);

 

    @CachePut(value="cash1")

    Enterprise save(Enterprise enterprise);

 

}

  自定义策略:key属性是用来指定Spring缓存方法的返回结果时对应的key的。该属性支持SpringEL表达式。当我们没有指定该属性时,Spring将使用默认策略生成key。

自定义策略是指我们可以通过Spring的EL表达式来指定我们的key。这里的EL表达式可以使用方法参数及它们对应的属性。使用方法参数时我们可以直接使用“#参数名”或者“#p参数index”。下面是几个使用参数作为key的示例。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

@Cacheable(value="users", key="#id")

 

   public User find(Integer id) {

      return null;

   }

 

   @Cacheable(value="users", key="#p0")

   public User find(Integer id) {

      return null;

   }

 

   @Cacheable(value="users", key="#user.id")

   public User find(User user) {

      return null;

   }

 

   @Cacheable(value="users", key="#p0.id")

   public User find(User user) {

      return null;

   }

  除了上述使用方法参数作为key之外,Spring还为我们提供了一个root对象可以用来生成key。通过该root对象我们可以获取到以下信息。

当我们要使用root对象的属性作为key时我们也可以将“#root”省略,因为Spring默认使用的就是root对象的属性。如:

1

2

3

4

5

@Cacheable(value={"users", "xxx"}, key="caches[1].name")

 

public User find(User user) {

   return null;

}

6、condition属性指定发生的条件

有的时候我们可能并不希望缓存一个方法所有的返回结果。通过condition属性可以实现这一功能。condition属性默认为空,表示将缓存所有的调用情形。其值是通过SpringEL表达式来指定的,当为true时表示进行缓存处理;当为false时表示不进行缓存处理,即每次调用该方法时该方法都会执行一次。如下示例表示只有当user的id为偶数时才会进行缓存。

1

2

3

4

5

@Cacheable(value={"users"}, key="#user.id", condition="#user.id%2==0")

public User find(User user) {

   System.out.println("find user by user " + user);

   return user;

}

二、@CachePut

在支持Spring Cache的环境下,对于使用@Cacheable标注的方法,Spring在每次执行前都会检查Cache中是否存在相同key的缓存元素,如果存在就不再执行该方法,而是直接从缓存中获取结果进行返回,否则才会执行并将返回结果存入指定的缓存中。@CachePut也可以声明一个方法支持缓存功能。与@Cacheable不同的是使用@CachePut标注的方法在执行前不会去检查缓存中是否存在之前执行过的结果,而是每次都会执行该方法,并将执行结果以键值对的形式存入指定的缓存中。
一般使用在保存,更新方法中。

@CachePut也可以标注在类上和方法上。使用@CachePut时我们可以指定的属性跟@Cacheable是一样的。

@CachePut(“users”)//每次都会执行方法,并将结果存入指定的缓存中

1

2

3

public User find(Integer id) {

      return null;

}

三、@CacheEvict

@CacheEvict是用来标注在需要清除缓存元素的方法或类上的。当标记在一个类上时表示其中所有的方法的执行都会触发缓存的清除操作。@CacheEvict可以指定的属性有value、key、condition、allEntries和beforeInvocation。其中value、key和condition的语义与@Cacheable对应的属性类似。即value表示清除操作是发生在哪些Cache上的(对应Cache的名称);key表示需要清除的是哪个key,如未指定则会使用默认策略生成的key;condition表示清除操作发生的条件。下面我们来介绍一下新出现的两个属性allEntries和beforeInvocation。
1、 allEntries属性
allEntries是boolean类型,表示是否需要清除缓存中的所有元素。默认为false,表示不需要。当指定了allEntries为true时,Spring Cache将忽略指定的key。有的时候我们需要Cache一下清除所有的元素,这比一个一个清除元素更有效率。

1

2

3

4

@CacheEvict(value="users", allEntries=true)

public void delete(Integer id) {

   System.out.println("delete user by id: " + id);

}

2、beforeInvocation属性
清除操作默认是在对应方法成功执行之后触发的,即方法如果因为抛出异常而未能成功返回时也不会触发清除操作。使用beforeInvocation可以改变触发清除操作的时间,当我们指定该属性值为true时,Spring会在调用该方法之前清除缓存中的指定元素。

1

2

3

4

@CacheEvict(value="users", beforeInvocation=true)

public void delete(Integer id) {

   System.out.println("delete user by id: " + id);

}

以上就是关于spring redis注解实现缓存机制的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

一文聊聊redis中的cluster集群

redis用户验证设置方法

redis error什么意思

redis怎么实现分布式事务

redis是什么

探索redis持久化原理

redis判断key是否存在

linux下重启redis的方法

redis 6.0版本新特性介绍

redis是原子性吗

更多相关阅读请进入《spring》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...