Hibernate学习:缓存

一:知识点

1:缓存概念与分类

缓存:在内存中开辟一块空间,把本来应该存储在数据库的数据,存储在硬盘上。

Hibernate有三种缓存:

一级缓存

二级缓存

查询缓存

2:各种缓存的特点

(1)session级别的缓存为一级缓存,session之间不能共享缓存

(2)二级缓存又叫sessionFactory级别的缓存,可以跨session

(3)查询缓存:重复性查询,查询对象跟条件一致,可以从二级缓存找。 如果查询不重复,不会使用二级缓存。

3:如何配置二级缓存

(1)、首先要打开二级缓存,在hibernate.cfg.xml中添加如下配置:

<property name="hibernate.cache.use_second_level_cache">true</property>

(2)、Hibernate的二级缓存使用第三方的缓存工具来实现,所以我们需要指定Hibernate使用哪个

缓存工具。如下配置指定Hibernate使用EhCache缓存工具。

<property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>

(3):加入ehcache.xml

<--

maxElementsInMemory 最大缓存对象

eternal = false内存可以清除

timeToIdleSeconds   如果对象多长时间没有查询,将对象清除

timeToLiveSeconds
对象最大生存时间,一般大于timeToIdleSeconds

overflowToDisk  内存溢出的时候,存放到硬盘上  <diskStore path="java.io.tmpdir"/>

-->

<defaultCache

maxElementsInMemory="10000"

eternal="false"

timeToIdleSeconds="120"

timeToLiveSeconds="120"

overflowToDisk="true"

/>

(4):在需要二级缓存的对象前面加上Annotation

@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)

@Entity

public class User {

执行查询,报错

Exception in thread "main" org.hibernate.HibernateException:

could not instantiate RegionFactory [org.hibernate.cache.impl.bridge.RegionFactoryCacheProviderBridge]

(5):需要加入Ecache的jar包ehcache-1.2.3.jar

执行查询

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory

(6):需要加入commons-logging-1.1.jar

二:缓存demo

时间: 2024-09-29 05:52:23

Hibernate学习:缓存的相关文章

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

hibernate学习笔记之三(一级缓存的使用和管理)

(hibernate学习笔记系列来自于 "疯狂Java" Hibernate视频学习) 一级缓存 一级缓存生命周期很短,与session生命周期一致,所以一级缓存也叫session级缓存或事务级缓存.位于缓存中的对象处于持久化状态,它与表中的相关记录对应,session能够在某些时间点,按照缓存中持久化对象的属性来同步数据库中表的记录,这一过程称为清理缓存. 一级缓存实现原理. session缓存是由它的实现类sessionImpl中定义的一些集合属性构成的,原理是保证有一个引用在关联

HIbernate学习笔记3 之 缓存和 对象的三种状态

一.hibernate一级缓存 *  hibernate创建每个Session对象时,都会给该Session分配一块独立的缓冲区,用于存放Session查询出来的对象,这个分配给session的缓存区也叫session级缓存.session取数据时,会优先向缓存区取数据,如果存在就直接取,不存在就去数据库查询,降低了数据库访问次数. * 一级缓冲是默认开启的,查询时会自动使用.每个session是独立的,save.update.delete.操作都会出发缓存更新. 二.缓存的管理 * sessi

Hibernate学习之一级缓存

? 版权声明:本文为博主原创文章,转载请注明出处 Hibernate缓存: - 缓存是为了降低应用程序对物理数据源访问的频次,从而提供应用程序的运行性能的一种策略 - Hibernate缓存是提升和优化Hibernate执行效率的重要手段 工作原理: 1. 应用程序读取缓存数据 2. 缓存命中则直接返回数据 3. 缓存未命中则去数据库中查询数据,然后将数据放入缓存中并返回数据 一级缓存: 1. Hibernate一级缓存又称为"Session缓存"."会话级缓存"

Hibernate学习---第四节:一级缓存

一.Hibernate 一级缓存的概念: 一级缓存生命周期很短与 session 生命周期一致,所以一级缓存也叫 session 级缓存或事务级缓存.位于缓存中的对象处于持久化状态,它和表中的相关记录对应,session 能够在某些时间点,按照缓存中持久化对象的属性变化来同步数据库中表的记录,这一过程称为清理缓存. (1).一级缓存实现原理.session 缓存是由它的实现类 sessionImpl 中定义的一些集合属性构成的,原理是保证有一个引用在关联着某个持久化对象,保持它的生命周期不会结束

Hibernate学习之缓存机制

转自:http://www.cnblogs.com/xiaoluo501395377/p/3377604.html 一.N+1问题 首先我们来探讨一下N+1的问题,我们先通过一个例子来看一下,什么是N+1问题:list()获得对象: /** * 此时会发出一条sql,将30个学生全部查询出来 */ List<Student> ls = (List<Student>)session.createQuery("from Student") .setFirstResu

hibernate学习(缓存)

缓存,介于应用程序和永久数据存储源之间,作用是为了降低应用程序对物理数据源访问的频率,从而提高应用的运行性能. 例如我们cpu执行效率每秒处理的数据高达上千兆,而我们的硬盘读取速度却没那么高,读取几百兆,这时候我们使用缓存来存储数据,存储满后一次性交由cpu处理. Hibernate中的缓存,同样是为了提高效率.Hibernate的缓存包括Session的缓存和SessionFactory的缓存. Session的缓存是内置的,不能被卸载,也被称为Hibertnate的一级缓存. Session

Hibernate学习笔记(一) — hibernate的配置文件简介与执行原理

一.初识Hibernate 1.JDBC的缺点: 1).编写代码的时候过于繁琐,try和catch比较多2).没有做数据缓存 3).不是面向对象编程 4).sql语句固定,可移植性差 JDBC的优点:效率比较高 2.Hibernate优点 1).完全面向对象编程 2).hibernate的缓存很牛的,一级缓存,二级缓存,查询缓存3).跨平台性强 4).使用场合多应用于企业内部的系统 Hibernate缺点 1).效率低 2).表中的数据如果在千万级别,则hibernate不适合 3).如果表与表

Hibernate学习汇总

一.Hibernate的基本原理 1.什么是Hibernate Hibernate,翻译过来是冬眠的意思,正好现在已经进入秋季,世间万物开始准备冬眠了.其实对于对象来说就是持久化. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的ORM框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库. Hibernate可以应用在任何使用JDBC的