• AOP中Cache操作实现


    AOP中Cache操作实现

    缓存应用场景

    在业务方法中我们可能调用数据层方法获取数据库中数据,假如访问数据的频率比较高,为了提高的查询效率,降低数据库的访问压力,可以在业务层对数据进行缓存.

    原理图

    使用Cache

    1. 开启配置

    在项目(SpringBoot项目)的启动类上添加@EnableCaching注解,以启动缓存配置。关键代码如下:

    @EnableCaching // 注解表示启动缓存配置
    @SpringBootApplication
    public class Application {
        
    	public static void main(String[] args) {
    		SpringApplication.run(Application.class, args);
    	}
     
    }
    

    2. 应用缓存配置

    在需要进行缓存的业务方法上通过@Cacheable注解对方法进行相关描述.表示方法的返回值要存储到Cache中,假如在更新操作时需要将cache中的数据移除,可以在更新方法上使用@CacheEvict注解对方法进行描述。例如:

    第一步:在相关模块查询相关业务方法中,使用缓存,关键代码如下

    // 在配置了@Cacheable以后, 这个方法返回值会存储到menuCache对应的缓存中.
    // 对于menusCache这个名字对应的缓存的key为实际参数组合后塍SimpleKey对象
    @Cacheable(value = "menuCache") // menuCache为缓存对象的名称(自己起)
    @Transactional(readOnly = true)
    public List<Map<String,Object>> findObjects() {
    ....
    }
    

    其中,value属性的值表示要使用的缓存对象,名字自己指定,其中底层为一个map对象,当向cache中添加数据时,key默认为方法实际参数的组合。

    第二步:在相关模块更新时,清除指定缓存数据,关键代码如下:

    @CacheEvict 注解描述的方法, 表示在方法业务指定过程中要清除缓存

    • value属性: 用于指定要清除的缓存对象
    • allEneries属性: 表示要清除缓存对象中的哪些属性(true)为所有
    • beforeInvocation属性: 表示清除缓存的动作在方法执行之后清除缓存
    @CacheEvict(value = "menuCache", allEntries = true, beforeInvocation = false)
    @Override
    public int saveObject(SysDept entity) {...}
    

    其中,allEntries表示清除所有。

  • 相关阅读:
    总结一些关于操作数据库是sql语句还是存储过程问题
    vs2010 创建预编译头 Debug 正常 Release Link Error问题解决
    创建Unicode格式的INI文件
    dos命令记录以及dos下通过进程id查找工作路径
    windows下多字节和宽字节转换
    关于多字节传输导致的乱码问题
    关于mysql数据库字符集优先级问题
    转: Apache开启gzip
    HTML 5 drag and drop 简介
    转: ES6异步编程: co函数库的含义与用法
  • 原文地址:https://www.cnblogs.com/zpKang/p/13374384.html
Copyright © 2020-2023  润新知