使用Spring3.1.1的緩存示例
定義數據訪問接口:
package org.kevin.cache.dao; import java.util.Collection; import org.kevin.cache.domain.Data; public interface DataDAO { public void add(Data data); public void update(Data data); public Data find(Integer id); public void delete(Integer id); public Collection<Data> getAll(); }
對接口方法進行實現,使用Map模擬數據庫的表進行存儲數據:
package org.kevin.cache.dao; import java.util.Collection; import java.util.HashMap; import java.util.Map; import org.kevin.cache.domain.Data; import org.springframework.cache.annotation.CacheEvict; import org.springframework.cache.annotation.Cacheable; public class DataDAOImpl implements DataDAO { private Map<Integer, Data> dataMap = new HashMap<>(); @Override @CacheEvict(value = "data", allEntries = true) public void add(Data data) { System.out.println("Execute:public void add(Data data)"); dataMap.put(data.getId(), data); } @Override @CacheEvict(value = "data", allEntries = true) public void update(Data data) { System.out.println("Execute:public void update(Data data) "); dataMap.put(data.getId(), data); } @Override @Cacheable(value = "data") public Data find(Integer id) { System.out.println("Execute:public Data find(Integer id)"); return dataMap.get(id); } @Override @CacheEvict(value = "data", allEntries = true) public void delete(Integer id) { System.out.println("Execute:public void delete(Integer id)"); dataMap.remove(id); } @Override @Cacheable(value = "data") public Collection<Data> getAll() { System.out.println("Execute:public Collection<Data> getAll()"); return dataMap.values(); } }
如上,對數據進行增刪改的時候清空緩存,查詢時使用緩存。其中value為緩存區,allEntries表示清空緩存區中的所有數據。為了稍后驗證緩存是否生效,打印出執行的方法簽名。
定義領域模型:
package org.kevin.cache.domain; public class Data { private Integer id; private String first; private String second; public Data(Integer id, String first, String second) { this.id = id; this.first = first; this.second = second; } public String getFirst() { return first; } public void setFirst(String first) { this.first = first; } public String getSecond() { return second; } public void setSecond(String second) { this.second = second; } public void setId(Integer id) { this.id = id; } public Integer getId() { return id; } }
接下來編寫spring配置文件:
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:cache="http://www.springframework.org/schema/cache" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-3.1.xsd"> <cache:annotation-driven /> <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> <bean id="dataDao" class="org.kevin.cache.dao.DataDAOImpl" /> </beans>
最后編寫main方法驗證緩存是否生效:
package org.kevin.cache; import java.util.Collection; import org.kevin.cache.dao.DataDAO; import org.kevin.cache.domain.Data; import org.springframework.context.support.ClassPathXmlApplicationContext; public class CacheMain { public static void main(String[] args) { ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring-cache-demo.xml"); DataDAO dataDAO = context.getBean("dataDao", DataDAO.class); dataDAO.add(new Data(1, "li", "wenkai")); Collection<Data> dataCollection = dataDAO.getAll(); System.out.println(dataCollection.size()); System.out.println("================================="); dataDAO.add(new Data(2, "jack", "lee")); dataCollection = dataDAO.getAll(); System.out.println(dataCollection.size());; Data data = dataDAO.find(1); System.out.println(data.getFirst()); data = dataDAO.find(2); System.out.println(data.getFirst()); data = dataDAO.find(2); System.out.println(data.getFirst());; System.out.println("===================================="); dataDAO.add(new Data(3, "kevin", "lee")); data = dataDAO.find(2); System.out.println(data.getFirst()); data = dataDAO.find(3); System.out.println(data.getFirst()); data = dataDAO.find(2); System.out.println(data.getFirst()); } }
打印接過如下,表示已經生效:
Execute:public void add(Data data) Execute:public Collection<Data> getAll() 1 ================================= Execute:public void add(Data data) Execute:public Collection<Data> getAll() 2 Execute:public Data find(Integer id) li Execute:public Data find(Integer id) jack jack ==================================== Execute:public void add(Data data) Execute:public Data find(Integer id) jack Execute:public Data find(Integer id) kevin jack
最后,spring支持的緩存機制,是方法級的緩存,而不關注底層是否使用了數據庫以及通過什么方式訪問的數據庫;因此這種緩存不止可以放到DAO層,也可以放置到Service層,甚至可以對各種代碼數據進行緩存。
如果應用中同時使用了Hibernate和Ibatis,或者這種方式是一種好的緩存解決方案。
轉自:http://blog.csdn.net/scorpio3k/article/details/7628894
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!