自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Hibernate的Query cache

開(kāi)發(fā) 后端
本文講述如何使用Hibernate的Query cache。Hibernate中的QueryCache用來(lái)緩存查詢語(yǔ)句,及查詢結(jié)果集中對(duì)象的Identifier與Type。

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

  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,并不是每一個(gè)第三方快取實(shí)現(xiàn)都支持所有的選項(xiàng),每一個(gè)選項(xiàng)的使用時(shí)機(jī)與支持的產(chǎn)品,可以直接參考Hibernate官方參考快冊(cè)的 20.2.The Second Level Cache;
 
在程序中需要為Query對(duì)象設(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)用以上代碼時(shí)你會(huì)發(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 

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

【編輯推薦】

  1. Hibernate中g(shù)enerator屬性的意義
  2. hibernate Key Generator 主鍵生成方式
  3. Hibernate的主鍵生成機(jī)制
  4. Hibernate緩存概述
  5. Hibernate中hbm的generator屬性
責(zé)任編輯:book05 來(lái)源: 和訊博客
相關(guān)推薦

2009-06-17 16:08:58

Hibernate C

2009-09-22 10:50:04

Hibernate c

2009-06-18 09:47:50

2009-09-24 18:11:56

Hibernate q

2010-07-05 09:07:42

2009-09-21 17:09:38

Hibernate C

2009-09-21 17:17:11

Hibernate二級(jí)

2009-06-18 12:59:39

Criteria Qu深入淺出Hiberna

2012-11-14 13:51:13

Mysqlquery cache

2010-05-19 16:39:11

MySQL查詢

2009-06-26 10:19:00

Clob字段Hibernate

2009-06-01 11:51:37

hibernate緩存機(jī)制開(kāi)發(fā)者

2009-06-26 10:32:00

QBC查詢Hibernate

2009-09-23 10:14:10

Hibernate使用

2009-09-28 13:43:28

使用Hibernate

2009-09-29 16:48:42

Hibernate J

2009-09-25 13:55:05

Hibernate使用

2009-09-21 17:23:49

Hibernate使用

2009-09-23 10:28:49

使用Hibernate

2009-06-30 16:52:30

DetchedCrit
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)