查询缓存:
首先明确查询缓存缓存的是什么?缓存的
key
是
HQL
语句与参数,缓存的
value
则是:
1、
如果查询的是普通结果集,则缓存这些结果集
2、
如果查询的是实体对象,则缓存的是实体对象的
ID
列表
3、
查询缓存它也是
SessionFactory
级别的缓存,由
sessionFactory
管理
现在看看使用查询缓存的三个步骤:
1、
在
Hibernate
配置文件中,启用查询缓存
<!--
配置打开查询缓存
-->
<property
name="hibernate.cache.use_query_cache">true</property>
2、
提供查询缓存的策略提供商,一般跟二级缓存的提供商是一样的
<!--
指定二级缓存和查询缓存的具体实现!
-->
<property
name="hibernate.cache.provider_class">
org.hibernate.cache.HashtableCacheProvider</property>
3、
查询之前调用
Query.setCacheable(true)
,这样查询缓存就起作用了。举个例子如下:
session.beginTransaction();
//查询缓存是SessionFactory级别的缓存
String hql = "select p.id,p.name from Person p";
List persons = session.createQuery(hql)
.setCacheable(true) //允许查询缓存!
.list();
for (Iterator iterator = persons.iterator(); iterator.hasNext();) {
Object[] datas = (Object[]) iterator.next();
System.out.println(datas[0]+","+datas[1]);
}
session.getTransaction().commit();
}catch(Exception e){
e.printStackTrace();
session.getTransaction().rollback();
}finally{
//session关闭之后,当前session对象中的一级缓存已经被清空
session.close();
}
Session session2 = HibernateUtil.openSession();
try{
session2.beginTransaction();
String hql = "select p.id,p.name from Person p";
//不发出sql语句
List persons = session2.createQuery(hql)
.setCacheable(true) //允许查询缓存!
.list();
for (Iterator iterator = persons.iterator(); iterator.hasNext();) {
Object[] datas = (Object[]) iterator.next();
System.out.println(datas[0]+","+datas[1]);
}
session2.getTransaction().commit();
接下来继续研究下:如果查询的参数不一致呢?
session.beginTransaction();
//如果查询参数不一样,最好不要使用查询缓存
String hql = "select p.id,p.name from ContactPerson p where p.name like ?";
List persons = session.createQuery(hql)
.setParameter(0, "%巴%")
.setCacheable(true) //允许查询缓存!
.list();
session2.beginTransaction();
String hql = "select p.id,p.name from ContactPerson p where p.name like ?";
List persons = session2.createQuery(hql)
.setParameter(0, "%特%")
.setCacheable(true) //允许查询缓存!
.list();
上面会发两条
sql
语句,因为查询的参数不一致。
查询缓存的
1+N
问题见
1+N
问题的文章!
总结:
-
要注意,查询缓存一般配合二级缓存一起使用
-
如果查询条件及其参数非常容易发生变化,请慎用查询缓存
-
注意理解查询缓存中的
N
个查询的问题!
分享到:
相关推荐
**hibernate缓存策略详解** Hibernate作为Java领域中广泛使用的ORM框架,其在处理大量数据时,为了提高性能和减少数据库的访问压力,引入了缓存机制。本文将深入探讨Hibernate的缓存策略,包括一级缓存、二级缓存...
### Hibernate的缓存策略 #### 一、缓存的基本概念 缓存技术是现代软件架构设计中的重要组成部分,尤其在数据库交互频繁的应用场景下尤为重要。简单来说,缓存是一种存储技术,位于应用程序与物理数据之间,目的是...
Hibernate缓存原理及调优策略 Hibernate缓存原理调优策略
### Hibernate缓存策略详解 #### 一、理解Hibernate缓存 ##### 1.1 缓存概念 在软件开发领域,缓存技术是一项重要的优化手段,它可以显著提高应用程序的性能和响应速度。Hibernate作为一种持久层框架,其核心功能...
### 深入理解Hibernate缓存 #### 一、Hibernate缓存概述 Hibernate作为一款流行的Java持久层框架,为开发者提供了高效且灵活的数据访问能力。其中,缓存机制是Hibernate性能优化的重要组成部分之一。理解Hibernate...
### Hibernate缓存技术研究 #### 一、引言 Hibernate是一种强大的对象-关系映射(Object-Relational Mapping,简称ORM)工具,主要用于Java环境下的应用程序。它能够将应用程序中的对象模型映射到关系型数据库的表...
Hibernate缓存可以针对实体类、集合类、SQL查询结果等设置不同的缓存区域。根据业务需求,可以自定义缓存策略,为不同类型的对象设置不同的缓存过期时间。 **六、缓存同步** 为了保证多线程环境下的数据一致性,...
Hibernate 缓存策略是优化应用程序性能的关键组成部分,尤其是在频繁访问数据库的情况下。缓存可以减少对物理数据库的直接访问,提高响应速度。本文将详细介绍Hibernate的一级缓存和二级缓存。 一级缓存,也称为...
这包括选择合适的缓存提供商、设置缓存策略、决定哪些实体或查询结果应放入缓存等。开发者需要根据业务需求和系统负载进行权衡,以达到最佳的缓存效果。 ### 总结 Hibernate的一级缓存、二级缓存和查询缓存共同...
因此,需要正确配置查询缓存的刷新策略,例如基于时间或者事件触发的刷新。 在"hibernate-test-project"这个压缩包中,我们可以找到一个具体的示例项目,通过代码来实践和理解这些缓存机制。项目中可能包含了配置...
### Hibernate缓存机制及优化策略 #### 一、概述 Hibernate作为一款优秀的对象关系映射(ORM)框架,在Java开发领域被广泛应用于数据库操作。它提供了丰富的缓存机制来提高应用性能并降低数据库访问压力。本文将...
综上所述,Hibernate缓存机制是提升应用性能的重要手段,通过合理配置缓存策略、优化查询方式、管理数据库连接以及实施有效的监控和调优措施,可以显著提高Hibernate应用的运行效率和用户体验。然而,缓存的使用并非...
【Hibernate缓存深入详解】 在Java的持久化框架Hibernate中,缓存机制是提升系统性能的关键因素。它位于Hibernate应用和数据库之间,减少了对数据库的直接访问,从而提高了应用程序的运行速度。缓存中存储的是...
Hibernate 是一个流行的对象关系映射(ORM)框架,它允许Java...通过理解Hibernate缓存和事务管理,以及如何有效地执行查询,开发者可以创建高效、健壮的Java应用程序,降低与数据库交互的复杂性,同时提升系统性能。
**Hibernate缓存详解** 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。为了提高数据访问性能,Hibernate引入了缓存机制,它可以减少对数据库的直接访问,从而提升应用的...
Hibernate缓存机制是提高应用程序性能的关键技术之一,它通过存储数据副本减少对物理数据库的访问。缓存可以分为两层:第一级缓存和第二级缓存。 **第一级缓存**是内置在Session中的,它是不可卸载的,也称为...
总的来说,尽管Hibernate的使用场景可能不像过去那么广泛,但其提供的对象关系映射、缓存机制和查询优化策略仍然是理解现代数据库操作和Java开发中的宝贵知识。了解并掌握这些技术,可以帮助开发者编写出更高效、更...
**标题:“Hibernate缓存与Spring事务详解”** 在IT领域,尤其是Java开发中,Hibernate作为一款流行的ORM(对象...在实际项目中,需要根据业务需求和场景选择合适的缓存策略和事务处理方式,以达到最佳的开发效果。