24、springboot与缓存(2)
生活随笔
收集整理的這篇文章主要介紹了
24、springboot与缓存(2)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
具體看上文!!!
?
@Service public class EmpService {@AutowiredEmployeeMapper employeeMapper;@Cacheable(cacheNames ="e")public Employee getEmp(Integer id){System.out.println("查詢:" + id +"員工");Employee emp = employeeMapper.getEmpById(id);return emp;} @CachePut(value = "e")public Employee update(Employee employee){System.out.println("update。。。。");employeeMapper.updateEmp(employee);return employee;} }?
?
@ResponseBody @RequestMapping("/emps") public Employee update(Employee employee){Employee emp = empService.update(employee);return emp; }?
?
@CachePut:即調用方法還更新數據 修改了數據庫同時更新緩存 1.運行時機先調用目標方法 2.將目標方法保存 步驟: 1、查詢1號員工,查到的結果會在緩存中 2、之后的查詢還是之前的結果 3、更細員工 4、再次查詢 此時的結果時之前的結果 1號員工沒有在緩存中更新?
此時測試流程:
?
此時的該標簽需要拿到返回值,且它的名字value和cacheName相同?
?
@CacheEvict:緩存清除 刪除指定的key @CacheEvict(value = "emp",key = "#id") public void del(Integer id){System.out.println("del:"+ id);//employeeMapper.deleteEmpById(id); } @ResponseBody @RequestMapping("/del") public String del(Integer id){empService.del(id);return "success del "; }?
假設同時查詢1,2兩個員工,然后刪除1,再去查2,依然不會調用數據庫
?
@CacheEvict(value = "e",allEntries = true) public void del(Integer id){System.out.println("del:"+ id);//employeeMapper.deleteEmpById(id); }?
假設同時查詢1,2兩個員工,然后刪除1,再去查2,會調用數據庫
?
?
@Caching()?定義復雜的緩存規則
@Target({ElementType.METHOD, ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Inherited @Documented public @interface Caching {Cacheable[] cacheable() default {};CachePut[] put() default {};CacheEvict[] evict() default {}; }?
?
EmployeeMapper.java @Select("SELECT * FROM employee WHERE lastName = #{lastName}") Employee getEmpByLastName(String lastName);?
?
EmpService.java
@Caching(cacheable = {@Cacheable(value = "emp",key = "#lastname")},put = {@CachePut(value = "emp",key = "#result.id"),@CachePut(value = "emp",key = "#result.email")} ) //此時會將該數據的id、email、lastname數據都加載緩存中 public Employee getByName(String lastname){return employeeMapper.getEmpByLastName(lastname); }?
此時可以將lastname、id、email都可以查詢的到
?
controller.java
@ResponseBody @RequestMapping("/caching/lastname/{lastname}") public Employee Cachings(@PathVariable("lastname") String lastname){Employee emp = empService.getByName(lastname);return emp; }?
?
此時查詢id=2的用戶依然會在緩存中進行查詢
控制臺并沒有進行打印。
?
?
@CacheConfig 緩存注解配置類,此時可以指定所有所有的value等屬性,不需要手動多次寫 @Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface CacheConfig {String[] cacheNames() default {};String keyGenerator() default "";String cacheManager() default "";String cacheResolver() default ""; }?
轉載于:https://www.cnblogs.com/Mrchengs/p/10435251.html
總結
以上是生活随笔為你收集整理的24、springboot与缓存(2)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++_异常6-其他异常特性
- 下一篇: SpiderData 2019年2月27