Query Cache 的使用
来源:互联网 发布:百度软件开发平台 编辑:程序博客网 时间:2024/04/30 14:40
老实说, 要做到在JDBC查询之前决定哪些数据需要从JDBC来还是CACHE来不是件容易事. 但是HIBERNATE还是很好地完成了这个任务. QueryCache用来缓存查询语句, 及查询结果集中对象的Identifier与Type. 当再次使用已缓存的Query时, 就可以通过对象的Identifier与Type在SECOND LEVEL CACHE中查找实际的对象.
使用QueryCache时需要在hibernate配置文件中设置如下属性:
代码
<property name="cache.provider_class">
org.hibernate.cache.HashtableCacheProvider
</property>
<property name="hibernate.cache.use_query_cache">true</property>
建立ehcache的配置文件ehcache.xml放在classpath下
<ehcache>
<diskStore path="java.io.tmpdir"/>
<defaultCache
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
/>
<cache name="com.fhway.hibernate.bean.Employee"
maxElementsInMemory="10"
eternal="false"
timeToIdleSeconds="100"
timeToLiveSeconds="100"
overflowToDisk="false"
/>
<cache name="com.fhway.hibernate.bean.Department"
maxElementsInMemory="10"
eternal="false"
timeToIdleSeconds="100"
timeToLiveSeconds="100"
overflowToDisk="false"
/>
</ehcache>
在配置文件里面要加入<cache>
如
<class name="com.fhway.hibernate.bean.Employee " table=" Employee ">
<cache usage="read-only"/>
可以设定的策略包括read-only、read-write、nonstrict-read-write与transactional,并不是每一个第三方快取实现都支持所有的选项,每一个选项的使用时机与支持的产品,可以直接参考Hibernate官方参考快册的 20.2.The Second Level Cache;
在程序中需要为Query对象设置Cachable属性:
代码
Query query = sess.createQuery("from Employee as employee");
query.setCacheable(true);
List employees = (List) query.list();
Iterator iterator = employees.iterator();
while(iterator.hasNext()){
System.out.println((Employee) iterator.next());
}
Query query1 = sess.createQuery("from Employee as employee");
query1.setCacheable(true);
List employees1 = (List) query1.list();
Iterator iterator1 = employee1.iterator();
while(iterator1.hasNext()){
System.out.println((Employee) iterator1.next());
}
Employee goncha = (Employee) sess.load(Employee.class, "001");
System.out.println(goncha);
当你调用以上代码时你会发现这样的输出:
Hibernate: select employee0_.ID as ID, employee0_.NAME as NAME0_, employee0_.DEPNO0 as DEPNO0_ from AFLYER.EMPLOYEE employee0_
com.fhway.hibernate.bean.Employee@e020c9
com.fhway.hibernate.bean.Employee@117f31e
com.fhway.hibernate.bean.Employee@bad8a8
com.fhway.hibernate.bean.Employee@104c575
com.fhway.hibernate.bean.Employee@e020c9
com.fhway.hibernate.bean.Employee@117f31e
com.fhway.hibernate.bean.Employee@bad8a8
com.fhway.hibernate.bean.Employee@104c575
com.fhway.hibernate.bean.Employee@e020c9
很显然 该缓存的利用方式对Query和load()方式有效!
Query上有list()与iterator()方法,两者的差别在于list()方法在读取数据时,并不会利用到快取,而是直接再向数据库查询,而iterator()则将读取到的数据写到快取,并于读取时再次利用。(Blob 不能使用cache)
- Query Cache 的使用
- mysql 的query cache
- MYSQL 的Query Cache
- MySQL的Query Cache
- query cache 的内存使用和调优
- Query Cache
- query cache
- 【mysql】mysql query cache配置与使用
- MySQL Query Cache效率的计算
- MySQL Query Cache 导致的崩溃?
- Mysql的查询缓存区query cache
- mysql中query cache的局限性
- MySQL的Query Cache原理分析
- mysql的Query Cache相关参数
- MySQL的Query Cache原理分析
- Hibernate 里 SQL 和 HQL,Criteria Query 对Session Cache缓存使用的不同
- 使用spring和hibernate配置ehcache和query cache
- 使用spring和hibernate配置ehcache和query cache
- 六十星系之54廉贞破军坐卯酉
- Hibernate学习笔记-HQL(Hibernate Query Language)
- ASP.NET常见问题
- 通往测试架构师之路:那些家伙在干什么?
- sql技巧
- Query Cache 的使用
- ASP.NETweb编程常用到的27个函数集
- C# 操作文件夹及文件
- ExtJS入门-概述
- Hibernate 中聚合函数的使用
- 环球旅行80天游戏分析【部分】
- servlet规范定义的Servlet 生命周期
- XML基础
- servlet实例的个数及因此引发的问题