- 浏览: 368696 次
文章分类
- 全部博客 (401)
- hibernate 入门 (24)
- it生活 (3)
- MapReduce 算法设计 (1)
- Android (13)
- java (6)
- web (4)
- 技术文章 (9)
- javascript (1)
- html5 (1)
- 数据库 (3)
- jquary (1)
- 1.网站首页原创Java技术区(对首页文章的要求: 原创、高质量、经过认真思考并精心写作。BlogJava管理团队会对首页的文章进行管理。) (0)
- 2.Java新手区 (0)
- 4.其他技术区 (0)
- 6.转载区(Java技术文章转载, 请注明原文出处) (0)
- 5.提问区(Java方面的技术提问) (0)
- servlet (1)
- IT 生活 (2)
- Struts2 (2)
- Struts 2 教程 (2)
- jQuery (1)
- DOM (1)
- ibatis,hibernate (1)
- 数据分析师 (1)
最新评论
-
NIIT_zhu:
我现在要做一个 基于exchange 2010的webmail ...
Exchange 2003 升级到Exchange 2010 之申请证书并分配服务! -
yinren13:
实在不行试试简单易用的turbomeeting,连接速度很快的 ...
QQ远程协助没动静?QQ版本有讲究 -
jicu7766240:
写得很好。赞一个!2年开发的我深有感触。这些我觉得说得很对。要 ...
老程序员的忠告:不要做浮躁的软件工程师 -
haohao-xuexi02:
好像很多人都买起却看不起书。。找各种理由不看。。我的书也这样 ...
老程序员的忠告:不要做浮躁的软件工程师 -
Judy123456:
希望可以提供源代码噢,我最近正好在学这个底部菜单,非常希望楼 ...
Android仿微信底部菜单
hibernate二级缓存本质上分为两类:
1.对象缓存
2.查询缓存 在JPA环境下,例如Jboss,底层还是通过Hibernate来实现JPA的Query。 下边简单说一下配置的步骤: 1.配置entity
在实体上方加入@Cache
CacheConcurrencyStrategy有几种,大家自己查下相关资料,按需要配置就可以了,我这里不需要事务支持.
需要注意的是,@Cache这个注解在很多jar包里都有,注意我上边写的import. 2.配置EJB/META-INF/persistence.xml
这里我使用了memcached,还有Ehcache、OSchache、或者TreeCache等,主要需配置:
hibernate.cache.use_second_level_cache = true
hibernate.cache.use_query_cache = true
与相应的hibernate.cache.provider_class 3.在程序中使用查询缓存
首先大家需要明确JPA对缓存的规范还没有形成,但JPA实现的厂家都会用hibernate来做JPA的实现,所以通常的方法是将JPA的Query转换成Hibernate的Query,大家用过Hibernate都知道,Hibernate里的Query有个setCacheable(true/false)的方法,这里是设置查询是否进入二级缓存的.
这里需要强调一下,默认的如果不在程序中显示的执行查询缓存声明操作,hibernate是不会对查询的list进行缓存的,默认的在开启hibernate二级缓存时,hibernate只缓存,根据主键id查找的对象,jpa下是find(id, clazz)方法. 下边是转换的代码:为了区分JPA的Query与Hibernate的Query,我写上了全名
这里再说一下使用经验,这样的转换不光是对createQuery方法,还能对createNamedQuery,甚至是createNativeQuery,都可以缓存查询结果.
1.对象缓存
2.查询缓存 在JPA环境下,例如Jboss,底层还是通过Hibernate来实现JPA的Query。 下边简单说一下配置的步骤: 1.配置entity
在实体上方加入@Cache
import java.io.Serializable;import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.Table; import org.hibernate.annotations.Cache; import org.hibernate.annotations.CacheConcurrencyStrategy; @Entity@Table@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)public class User implements Serializable {private static final long serialVersionUID = -5121812640999313420L; private Integer id; private String name; @Id@GeneratedValue public Integer getId() { return id;}public void setId(Integer id) { this.id = id;}public String getName() { return name;}public void setName(String name) {this.name = name;} }
CacheConcurrencyStrategy有几种,大家自己查下相关资料,按需要配置就可以了,我这里不需要事务支持.
需要注意的是,@Cache这个注解在很多jar包里都有,注意我上边写的import. 2.配置EJB/META-INF/persistence.xml
<?xml version="1.0" encoding="UTF-8"?><!-- Persistence deployment descriptor for dev profile --><persistence xmlns="http://java.sun.com/xml/ns/persistence"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"version="1.0"><persistence-unit name="cachedb"><jta-data-source>java:/cachedb</jta-data-source><properties><property name="hibernate.hbm2ddl.auto" value="update" /><property name="hibernate.show_sql" value="true" /><property name="hibernate.format_sql" value="true" /><property name="hibernate.cache.use_second_level_cache" value="true" /><property name="hibernate.cache.use_structured_entries" value ="true" /><property name="hibernate.cache.use_query_cache" value="true" /><property name="hibernate.cache.provider_class" value="com.googlecode.hibernate.memcached.MemcachedCacheProvider" /><property name="hibernate.memcached.servers" value="localhost:11211" /><property name="hibernate.memcached.cacheTimeSeconds" value="300" /></properties></persistence-unit></persistence>
这里我使用了memcached,还有Ehcache、OSchache、或者TreeCache等,主要需配置:
hibernate.cache.use_second_level_cache = true
hibernate.cache.use_query_cache = true
与相应的hibernate.cache.provider_class 3.在程序中使用查询缓存
首先大家需要明确JPA对缓存的规范还没有形成,但JPA实现的厂家都会用hibernate来做JPA的实现,所以通常的方法是将JPA的Query转换成Hibernate的Query,大家用过Hibernate都知道,Hibernate里的Query有个setCacheable(true/false)的方法,这里是设置查询是否进入二级缓存的.
这里需要强调一下,默认的如果不在程序中显示的执行查询缓存声明操作,hibernate是不会对查询的list进行缓存的,默认的在开启hibernate二级缓存时,hibernate只缓存,根据主键id查找的对象,jpa下是find(id, clazz)方法. 下边是转换的代码:为了区分JPA的Query与Hibernate的Query,我写上了全名
public List<User> listUser() {javax.persistence.Query query = em.createQuery("from User u where u.id>:id", User.class);query.setParameter("id", 5);org.hibernate.ejb.QueryImpl hs = null;org.hibernate.Query hbQuery = null;List<User> list = null;if(query instanceof org.hibernate.ejb.QueryImpl) {hs = (org.hibernate.ejb.QueryImpl)query;hbQuery = hs.getHibernateQuery();hbQuery.setCacheable(true);//设置使用二级缓存list = hbQuery.list();} else {list = query.getResultList();}return list;}
这里再说一下使用经验,这样的转换不光是对createQuery方法,还能对createNamedQuery,甚至是createNativeQuery,都可以缓存查询结果.
发表评论
-
Hibernate里面使用sql查询
2012-04-11 10:17 4079hibernate3.0中是可以使用sql语句,但一般还 ... -
Hibernate工作原理及使用理由
2012-04-11 10:01 16901.读取并解析配置文件2.读取并解析映射信息,创建S ... -
hibernate+sqlserver中文乱码的解决
2012-04-10 08:03 1801首先要编写一个编码过滤器,起编码如下: pa ... -
spring 配置 hibernate 二级缓存
2012-04-10 08:01 1535今天在配置spring + hibernate过程中出现些问题 ... -
spring + hibernate 二级缓存 ehcache
2012-04-09 10:05 12571:配置spring 文件 在sessionfactiory ... -
实现OSCache二级缓存的配置方案
2012-04-09 10:03 1071今天在使用hibernate的时候要配置二级缓存,给大家分享一 ... -
hibernate HQL 查询使用详解
2012-04-13 23:45 3666Hibernate Query Language(HQL)提供 ... -
Hibernate JPA 的索引的使用
2012-04-13 23:44 911在Hibernate中Model中一个对象关联的对象相当多是必 ... -
Hibernate分页查询(使用HQL语言)
2012-04-12 21:29 1172例: import java.util.Iterator ... -
使用hibernate的HQL查询语言时参数需要为String类型
2012-04-12 21:29 1113本人新手,在使用hibernate的HQL查询语言时传进来的参 ... -
Hibernate缓存何时使用和如何使用
2012-04-12 21:29 1020<hibernate-mapping> < ... -
使用Hibernate实现多表查询
2012-04-12 21:29 1247项目中使用的是Hibernate框架,对于表查询一直只针对一张 ... -
Hibernate里面使用sql查询
2012-04-12 21:28 1003hibernate3.0中是可以使用sql语句,但一般还是hq ... -
Hibernate工作原理及使用理由
2012-04-08 13:31 01.读取并解析配置文件 2.读取并解析映射信息,创建Sess ... -
hibernate+sqlserver中文乱码的解决
2012-04-08 13:30 0首先要编写一个编码过滤器,起编码如下: pack ... -
spring + hibernate 二级缓存 ehcache
2012-04-08 13:28 01:配置spring 文件 在sessionfacti ... -
实现OSCache二级缓存的配置方案
2012-04-08 13:23 0我在这里以应用十分广泛的OSCache第三方缓存框架为例,谈谈 ... -
Hibernate事务处理机制----2
2012-04-08 13:20 917二、JTATransaction 如果你 ... -
Hibernate事务处理机制--1
2012-04-08 13:17 1028Hibernate是对JDBC的轻量级对象封装,Hiberna ... -
Hibernate缓存
2012-04-08 13:15 1108hibernate的session提供了一级缓存,每个sess ...
相关推荐
通过以上步骤,我们就成功地在Spring Boot 2.1.4.RELEASE项目中配置了使用Redis作为Hibernate二级缓存的环境。这将显著提升数据库查询效率,减少对数据库的压力,尤其在高并发场景下,效果尤为明显。记得在实际生产...
**一、Hibernate二级缓存** Hibernate一级缓存是指Session级别的缓存,它是默认开启的,每个Session都会维护一个对象缓存,用来存放该Session加载的实体对象。一级缓存的生命周期与Session相同,当Session关闭时,...
总结来说,JPA的二级缓存是一个强大的工具,能提高大数据量场景下的应用性能。但使用时需谨慎,确保数据一致性,并根据具体业务场景进行合理配置和优化。正确地利用二级缓存,将大大提高系统的响应速度,降低数据库...
在本配置中,Hibernate版本为5.1.3,支持JPA规范,提供了二级缓存功能,提高了数据访问性能。 4. **二级缓存(Ehcache)**: Ehcache是Hibernate的一个可选二级缓存插件,用于存储数据库查询结果,减少对数据库的...
压缩包中的"Hibernate二级缓存实例"应该包含了具体的配置文件、实体类、以及如何使用缓存的代码示例。通过学习这个实例,你可以了解到如何在项目中设置和利用Hibernate的二级缓存,从而提升应用的性能。 总结来说,...
**标题:“Hibernate二级缓存的应用”** 在Java的持久化框架Hibernate中,一级缓存是默认存在的,每个Session都有自己的缓存,而二级缓存则是可选的,它跨越了多个Session,为整个SessionFactory提供数据共享。二级...
总之,Spring Boot通过starter-data-jpa模块和Hibernate、Ehcache整合,为我们提供了一个强大的工具集,可以有效地实现二级缓存机制,优化应用性能,减少数据库压力。开发者需要掌握这些知识点,以确保在实际的项目...
4. **缓存机制**: 提供了第一级缓存和第二级缓存,提高性能。 **jar包的重要性**: 在`jpa-hibernate`这个压缩包中,包含的jar包是运行JPA基于Hibernate的应用所必需的依赖。这些库提供了JPA规范的实现以及...
Hibernate不仅实现了JPA规范,还提供了许多额外的功能,如二级缓存、查询语言HQL和 Criteria API等,极大地简化了Java开发人员与数据库交互的工作。 在"jpa之使用hibernate示例代码"中,我们可能会涉及以下关键知识...
Hibernate不仅实现了JPA规范,还额外提供了一些特性,如二级缓存、更灵活的查询选项和性能优化工具。 **JPA核心概念:** 1. **实体(Entity)**:在JPA中,实体是映射到数据库表的Java类。通过在类上添加`@Entity`...
例如,在实体对象的状态方面,Hibernate定义了“瞬态”、“持久化”和“分离”等状态,而JPA则使用“new”、“managed”、“detached”和“removed”等术语来描述类似的概念。这些相似之处使得从Hibernate迁移到JPA...
1. **缓存(Caching)**:一级缓存(Session级别的)和二级缓存(SessionFactory级别的)可以提高性能,减少对数据库的访问。 2. **批处理(Batching)**:通过设置批处理大小,可以减少数据库交互次数,提高效率。...
Hibernate不仅实现了JPA规范,还添加了自己的特性,如二级缓存、 Criteria查询和HQL(Hibernate Query Language)。 **搭建JPA with Hibernate环境** 需要以下步骤: 1. **添加依赖**:在项目中引入Hibernate和JPA...
Hibernate不仅提供了JPA规范的所有功能,还额外提供了一些高级特性,如二级缓存、CGLIB动态代理等。在Hibernate中,反向工程(Reverse Engineering)是一种工具,可以从现有数据库生成Java类,这些类代表数据库中的...
Ehcache 是一个纯 Java 的缓存框架,既可以当做一个通用缓存使用,也可以作为 Hibernate 的二级缓存使用。缓存数据可选择如下三种存储方案: 1. MemoryStore – On-heap memory used to hold cache elements. This ...
它不仅支持JPA的标准特性,还提供了额外的工具和配置选项,例如二级缓存、事件监听器、CGLIB和ASM动态代理等,使得开发者可以更高效地处理数据库操作。 **JPA的核心概念** 1. **实体(Entity)**:在JPA中,实体是...
Hibernate提供了更丰富的API,可以处理更复杂的数据操作,包括事务管理、查询语言(HQL)和第二级缓存等。在JPA_Hibernate项目中,Hibernate被用作与数据库交互的主要工具。 **jar包**(Java Archive)是Java平台...
对于复杂的应用场景,可能需要配置更多的Spring和Hibernate特性,例如二级缓存、查询缓存、拦截器等。同时,结合Spring MVC或Spring Boot等Web框架,可以构建出完整的、高度可扩展的企业级应用。 总之,Spring与JPA...
commons-logging-1.1.1.jar,dom4j-1.6.1.jar,ehcache-1.5.0.jar,hibernate3.jar,hibernate-jpa-2.0-api-1.0.0.Final.jar,javassist-3.12.0.GA.jar,jta-1.1.jar,slf4j-api-1.6.1.jar,slf4j-log4j12-1.6.1.jar...