日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
使用Hibernate的Querycache

老實(shí)說, 要做到在JDBC查詢之前決定哪些數(shù)據(jù)需要從JDBC來還是CACHE來不是件容易事. 但是HIBERNATE還是很好地完成了這個任務(wù). QueryCache用來緩存查詢語句, 及查詢結(jié)果集中對象的Identifier與Type. 當(dāng)再次使用已緩存的Query時, 就可以通過對象的Identifier與Type在SECOND LEVEL CACHE中查找實(shí)際的對象.
 
使用hibernate中的QueryCache時需要在hibernate配置文件中設(shè)置如下屬性:

阿拉山口網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)于2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運(yùn)維經(jīng)驗,來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)

 
 
 
  1. < property name="cache.provider_class"> 
  2.        org.hibernate.cache.HashtableCacheProvider  
  3. < /property> 
  4. < property name="hibernate.cache.use_query_cache">true< /property> 

建立ehcache的配置文件ehcache.xml放在classpath下

 
 
 
  1. < ehcache>   
  2.     < diskStore path="java.io.tmpdir"/>   
  3.     < defaultCache   
  4.         maxElementsInMemory="10000"   
  5.         eternal="false"   
  6.         timeToIdleSeconds="120"   
  7.         timeToLiveSeconds="120"   
  8.         overflowToDisk="true"   
  9.         />   
  10.    
  11.     < cache name="com.fhway.hibernate.bean.Employee"   
  12.         maxElementsInMemory="10"   
  13.         eternal="false"   
  14.         timeToIdleSeconds="100"   
  15.         timeToLiveSeconds="100"   
  16.         overflowToDisk="false"   
  17.         />   
  18.    
  19.     < cache name="com.fhway.hibernate.bean.Department"   
  20.         maxElementsInMemory="10"   
  21.         eternal="false"   
  22.         timeToIdleSeconds="100"   
  23.         timeToLiveSeconds="100"   
  24.         overflowToDisk="false"   
  25.         />   
  26.     
  27. < /ehcache> 

在配置文件里面要加入< cache>

 
 
 
  1. < class name="com.fhway.hibernate.bean.Employee " table=" Employee "> 
  2.         < cache usage="read-only"/> 

可以設(shè)定的策略包括read-only、read-write、nonstrict-read-write與transactional,并不是每一個第三方快取實(shí)現(xiàn)都支持所有的選項,每一個選項的使用時機(jī)與支持的產(chǎn)品,可以直接參考Hibernate官方參考快冊的 20.2.The Second Level Cache;
 
在程序中需要為Query對象設(shè)置Cachable屬性:

 
 
 
  1. Query query = sess.createQuery("from Employee as employee");  
  2. query.setCacheable(true);    
  3. List employees = (List) query.list();  
  4. Iterator iterator = employees.iterator();  
  5. while(iterator.hasNext()){  
  6.        System.out.println((Employee) iterator.next());  
  7. }  
  8.    
  9. Query query1 = sess.createQuery("from Employee as employee");  
  10. query1.setCacheable(true);    
  11. List employees1 = (List) query1.list();  
  12. Iterator iterator1 = employee1.iterator();  
  13. while(iterator1.hasNext()){  
  14.        System.out.println((Employee) iterator1.next());  
  15. }  
  16. Employee goncha = (Employee) sess.load(Employee.class, "001");  
  17. System.out.println(goncha);   

當(dāng)你調(diào)用以上代碼時你會發(fā)現(xiàn)這樣的輸出:

 
 
 
  1. Hibernate: select employee0_.ID as ID, employee0_.NAME as NAME0_, employee0_.DEPNO0 as DEPNO0_ from AFLYER.EMPLOYEE employee0_  
  2. com.fhway.hibernate.bean.Employee@e020c9  
  3. com.fhway.hibernate.bean.Employee@117f31e  
  4. com.fhway.hibernate.bean.Employee@bad8a8  
  5. com.fhway.hibernate.bean.Employee@104c575  
  6. com.fhway.hibernate.bean.Employee@e020c9  
  7. com.fhway.hibernate.bean.Employee@117f31e  
  8. com.fhway.hibernate.bean.Employee@bad8a8  
  9. com.fhway.hibernate.bean.Employee@104c575  
  10. com.fhway.hibernate.bean.Employee@e020c9 

很顯然 該緩存的利用方式對Query和load()方式有效!
Query上有l(wèi)ist()與iterator()方法,兩者的差別在于list()方法在讀取數(shù)據(jù)時,并不會利用到快取,而是直接再向數(shù)據(jù)庫查詢,而iterator()則將讀取到的數(shù)據(jù)寫到快取,并于讀取時再次利用。(Blob 不能使用cache)


本文名稱:使用Hibernate的Querycache
URL分享:http://m.5511xx.com/article/ccdcced.html