使用Hibernate的Query cache
创始人
2024-04-07 13:20:44
0

老实说, 要做到在JDBC查询之前决定哪些数据需要从JDBC来还是CACHE来不是件容易事. 但是HIBERNATE还是很好地完成了这个任务. QueryCache用来缓存查询语句, 及查询结果集中对象的Identifier与Type. 当再次使用已缓存的Query时, 就可以通过对象的Identifier与Type在SECOND LEVEL CACHE中查找实际的对象.
 
使用hibernate中的QueryCache时需要在hibernate配置文件中设置如下属性:

  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"/> 

可以设定的策略包括read-only、read-write、nonstrict-read-write与transactional,并不是每一个第三方快取实现都支持所有的选项,每一个选项的使用时机与支持的产品,可以直接参考Hibernate官方参考快册的 20.2.The Second Level Cache;
 
在程序中需要为Query对象设置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);   

当你调用以上代码时你会发现这样的输出:

  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上有list()与iterator()方法,两者的差别在于list()方法在读取数据时,并不会利用到快取,而是直接再向数据库查询,而iterator()则将读取到的数据写到快取,并于读取时再次利用。(Blob 不能使用cache)

【编辑推荐】

  1. Hibernate中generator属性的意义
  2. hibernate Key Generator 主键生成方式
  3. Hibernate的主键生成机制
  4. Hibernate缓存概述
  5. Hibernate中hbm的generator属性

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...