spring自帶緩存機制


@Cacheable支持如下參數:負責將方法的返回值加入到緩存中
value:緩存位置名稱,不能為空.
key:緩存的key,默認為空,支持springEL表達式.
condition:觸發條件,只有滿足條件的情況下才會加入緩存,默認為空,表示全部加入緩存,支持springEL表達式.
@CachEvict支持如下參數:負責清除緩存.
value:緩存位置名稱,不能為空.
key:緩存的key,默認為空,支持springEL表達式.
condition:觸發條件,只有滿足條件的情況下才會清除緩存,默認為空,支持springEL表達式.
allEntries:ture表示清除value中的全部緩存,默認為false.

 

 

 編寫dao

  • @Override
  • @CacheEvict(value = "data", allEntries = true)
  • public void add(User user) {
  • System.out.println( "UserService: method- add(User user)" );
  • userDao.add(user);
  • }
  •  
  • @Override
  • @CacheEvict(value = "data", allEntries = true)
  • public void delete(String id) {
  • System.out.println( "UserService: method-delete(String id)" );
  • userDao.delete(id);
  • }
  •  
  • @Override
  • @CacheEvict(value = "data", allEntries = true)
  • public void update(User user) {
  • System.out.println( "UserService: method-update(User user)" );
  • userDao.update(user);
  • }
  •  
  • @Override
  • @Cacheable(value = "data")
  • public User find(String id) {
  • System.out.println( "UserService: method-find(String id)" );
  • return userDao.find(id);
  • }
  •  
  • @Override
  • @Cacheable(value = "data")
  • public Map<String, User> getAll() {
  • System.out.println( "UserService: method-getAll()" );
  • return userDao.getAll();
  • }
     
     
    配置的xml
    • <!-- 應用spring cache注解功能 -->
    • <cache:annotation-driven />
    •  
    • <!-- 創建spring cache bean -->
    • <bean id="cacheManager" class="org.springframework.cache.support.SimpleCacheManager">
    • <property name="caches">
    • <set>
    • <bean
    • class="org.springframework.cache.concurrent.ConcurrentMapCacheFactoryBean"
    • p:name="default" />
    • <bean
    • class="org.springframework.cache.concurrent.ConcurrentMapCacheFactoryBean"
    • p:name="data" />
    • </set>
    • </property>
    • </bean>
     

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM