欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Springboot使用@Cacheable注解實現(xiàn)數(shù)據(jù)緩存

 更新時間:2023年10月09日 10:39:10   作者:sg_knight  
本文介紹如何在Springboot中通過@Cacheable注解實現(xiàn)數(shù)據(jù)緩存,在每次調(diào)用添加了@Cacheable注解的方法時,Spring 會檢查指定參數(shù)的指定目標方法是否已經(jīng)被調(diào)用過,文中有詳細的代碼示例,需要的朋友可以參考下

1、添加 @EnableCaching

使用 @EnableCaching 標識在 SpringBoot 的主啟動類上,開啟基于注解的緩存。

@EnableCaching
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application .class, args);
    }
}

2、添加@Cacheable

在需要緩存的方法上添加@Cacheable注解。以后查詢相同的數(shù)據(jù),直接從緩存中取,不需要調(diào)用方法。

@Cacheable(value = "areaTreeData")
public CommonResult<List<Map<String, Object>>> queryTreeData(Long pId, Long lv) {
  Map<String, Object> map = new HashMap<>();
  map.put("state", 1);
  List<Map<String, Object>> list = getTreeData(map, pId, lv);
  return new CommonResult<>(list);
}

注意:

1、返回的數(shù)據(jù)類型必須支持序列化或?qū)崿F(xiàn)了Serializable接口,否則數(shù)據(jù)沒法緩存。

2、只有直接調(diào)用該方法才能緩存,不能通過類中的其他方法來調(diào)用。

3、常用屬性說明

  • cacheNames/value :用來指定緩存組件的名字
  • key :緩存數(shù)據(jù)時使用的 key,可以用它來指定。默認是使用方法參數(shù)的值。(這個 key 你可以使用 spEL 表達式來編寫)
  • keyGenerator :key 的生成器。 key 和 keyGenerator 二選一使用
  • cacheManager :可以用來指定緩存管理器。從哪個緩存管理器里面獲取緩存。
  • condition :可以用來指定符合條件的情況下才緩存
  • unless :否定緩存。當 unless 指定的條件為 true ,方法的返回值就不會被緩存。當然你也可以獲取到結(jié)果進行判斷。(通過 #result 獲取方法結(jié)果)
  • sync :是否使用異步模式。

4、@CacheEvict注解

@CachEvict 的作用 主要針對方法配置,能夠根據(jù)一定的條件對緩存進行清空。常用屬性參數(shù)如下:

參數(shù)解釋example
value緩存的名稱,在 spring 配置文件中定義,必須指定至少一個@CacheEvict(value=”my cache”)
key緩存的 key,可以為空,如果指定要按照 SpEL 表達式編寫,如果不指定,則缺省按照方法的所有參數(shù)進行組合@CacheEvict(value=”testcache”,key=”#userName”)
condition緩存的條件,可以為空,使用 SpEL 編寫,返回 true 或者 false,只有為 true 才進行緩存@CacheEvict(value=”testcache”,condition=”#userName.length()>2”)
allEntries是否清空所有緩存內(nèi)容,缺省為 false,如果指定為 true,則方法調(diào)用后將立即清空所有緩存@CachEvict(value=”testcache”,allEntries=true)
beforeInvocation是否在方法執(zhí)行前就清空,缺省為 false,如果指定為 true,則在方法還沒有執(zhí)行的時候就清空緩存,缺省情況下,如果方法執(zhí)行拋出異常,則不會清空緩存@CachEvict(value=”testcache”,beforeInvocation=true)
@CacheEvict(value = "areaTreeData", allEntries = true, beforeInvocation = true)
public Integer save(SysArea sysArea) {
   return mapper.insertSelective(sysArea);
}

以上就是Springboot使用@Cacheable注解實現(xiàn)數(shù)據(jù)緩存的詳細內(nèi)容,更多關于Springboot數(shù)據(jù)緩存的資料請關注腳本之家其它相關文章!

相關文章

  • 詳解SpringBoot下文件上傳與下載的實現(xiàn)

    詳解SpringBoot下文件上傳與下載的實現(xiàn)

    這篇文章主要介紹了SpringBoot下文件上傳與下載的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • Java FastJson使用教程

    Java FastJson使用教程

    這篇文章主要介紹了如何使用FastJson,幫助大家將 Java 對象轉(zhuǎn)換為 JSON 格式,感興趣的朋友可以了解下
    2020-10-10
  • java設計模式之單例模式

    java設計模式之單例模式

    這篇文章主要為大家詳細介紹了java設計模式之單例模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • 詳解基于java的Socket聊天程序——服務端(附demo)

    詳解基于java的Socket聊天程序——服務端(附demo)

    這篇文章主要介紹了詳解基于java的Socket聊天程序——服務端(附demo),具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-12-12
  • 深度解析MyBatis?動態(tài)?SQL?與緩存機制

    深度解析MyBatis?動態(tài)?SQL?與緩存機制

    本文從動態(tài)SQL核心語法、緩存實現(xiàn)原理、性能優(yōu)化及面試高頻問題四個維度,結(jié)合源碼與工程實踐,系統(tǒng)解析MyBatis的核心特性與最佳實踐,感興趣的朋友一起看看吧
    2025-06-06
  • 基于SpringBoot?使用?Flink?收發(fā)Kafka消息的示例詳解

    基于SpringBoot?使用?Flink?收發(fā)Kafka消息的示例詳解

    這篇文章主要介紹了基于SpringBoot?使用?Flink?收發(fā)Kafka消息,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • Spring框架的環(huán)境搭建和測試實現(xiàn)

    Spring框架的環(huán)境搭建和測試實現(xiàn)

    這篇文章主要介紹了Spring框架的環(huán)境搭建和測試實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10
  • 深入淺出分析Java 類和對象

    深入淺出分析Java 類和對象

    面向?qū)ο竽耸荍ava語言的核心,是程序設計的思想。Java語言的面向?qū)ο蠹夹g包括了面向?qū)ο蠛兔嫦蜻^程的基本概念,面向?qū)ο蟮奶卣鳎琂ava語言的類,對象,修飾符,抽象類等一系列的知識點
    2022-03-03
  • spring boot與ktor整合的實現(xiàn)方法

    spring boot與ktor整合的實現(xiàn)方法

    這篇文章主要給大家介紹了關于spring boot與ktor整合的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • idea +junit單元測試獲取不到bean注入的解決方式

    idea +junit單元測試獲取不到bean注入的解決方式

    這篇文章主要介紹了idea +junit單元測試獲取不到bean注入的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08

最新評論