一篇文章讲明白hiberbnate缓存策略概述

简介: 一篇文章讲明白hiberbnate缓存策略概述

1. 首先了解什么是缓存

这里说的缓存并不是指计算机的内存或者CPU的一二级缓存。

缓存是指为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能的一种策略。即对物理数据源的复制,存在于内存中。

为什么使用缓存:

1.ORM框架访问数据库的效率直接影响应用程序的运行速度,提升和优化ORM框架的执行效率至关重要。

2.Hibernate的缓存是提升和优化Hibernate执行效率的重要手段,所以学会Hibernate缓存的使用和配置是优化的关键。

3.评判一个ORM框架是否优秀,访问数据库的频次就是一个重要的标准。

Hibernate缓存:

1.Hibernate缓存与session相关,同一个session第二次访问同一个对象将使用缓存。

2.在不同//代码效果参考:http://www.zidongmutanji.com/bxxx/33860.html

的session中多次查询同一个对象时,会执行多次数据库查询。

3.在一级缓存当中,持久化类的每个实例都具有唯一的OID,也就是说同一个session两次查询同一个对象时,第二次是不会再将对象保存在缓存当中的。

2. 由下列代码可知使用缓存和不使用缓存的一些区别:

即:

3. hibernate一级缓存介绍

3.1 一级缓存session 的相关API 【一级缓存无法取消,用两个方法管理——evict() & clear() 】(执行两者之后都将在控制台重新输出查询语句)

Employee emp=(Employee) session.get(Employee.class,1);

System.out.println(emp.getName());

// 创建另一新的缓存

// session =sessionFactory.openSession();

session.evict(emp);//将该对象从一级缓存中清除

// session.clear();//清除一级缓存中的所有内容

emp=(Employee) session.get(Employee.class,1);

System.out.println(emp.getName());

3.2 关于遍历操作的两个方法之间的区别【 list() & iterate() 】

3.2.1 list()遍历查询

结论: query.list() 不会使用到缓存

3.2.2 iterate()遍历查询

Query query =session.createQuery("from Employee");

// List list //代码效果参考:http://www.zidongmutanji.com/zsjx/36663.html

=query.list();

// for(Employee emp:list){

// System.out.println(emp.getName());

// }

Iterator it =query.iterate();

while(it.hasNext()){

Employee emp=(Employee)it.next();

System.out.println(emp.getName());

}

取消注释时,由于list()查询后session中已有数据,这时iterate()方法会从缓存中获取所需数据

执行注释时,iterate()方法依然会先从缓存中查找,因为缓存中没有所需的数据,这时会再从数据库中查找

3.2.3 小结一级缓存:

只能在一次会话中或者只在本次session 中起作用,这是hibernate 自带的不可消除,query 创建的查询create query (from 对象)表示查询所有的信息,query.list 不能从session 中获取缓存但可以存缓存。迭代器查询所有,先查询所有对象中的id 然后通过id 在session 缓存中查取id 所对应的所有信息,有几个id向数据库发送几次操作或者说是执行几次查询语句。

4. 二级缓存(解决一个session在其他session中能直接使用问题)

标签( .hbm.xml文件)

标签介绍:

5. 一二级缓存对比

总结:

1)hibernate的缓存能提高检索效率

2)hibernate的缓存分为一级缓存和二级缓存。一级缓存是会话级缓存,二级缓存是应用级缓存。

3)hibernate的缓存在提高检索的同时,也会增加服务器的消耗,所以注意缓存的使用策略。

相关文章
|
1月前
|
缓存 算法 数据挖掘
深入理解缓存更新策略:从LRU到LFU
【10月更文挑战第7天】 在本文中,我们将探讨计算机系统中缓存机制的核心——缓存更新策略。缓存是提高数据检索速度的关键技术之一,无论是在硬件还是软件层面都扮演着重要角色。我们会详细介绍最常用的两种缓存算法:最近最少使用(LRU)和最少使用频率(LFU),并讨论它们的优缺点及适用场景。通过对比分析,旨在帮助读者更好地理解如何选择和实现适合自己需求的缓存策略,从而优化系统性能。
45 3
|
3月前
|
缓存 Java
Java本地高性能缓存实践问题之Caffeine缓存库中基于时间设置驱逐策略的问题如何解决
Java本地高性能缓存实践问题之Caffeine缓存库中基于时间设置驱逐策略的问题如何解决
|
19天前
|
存储 缓存 监控
利用 Redis 缓存特性避免缓存穿透的策略与方法
【10月更文挑战第23天】通过以上对利用 Redis 缓存特性避免缓存穿透的详细阐述,我们对这一策略有了更深入的理解。在实际应用中,我们需要根据具体情况灵活运用这些方法,并结合其他技术手段,共同保障系统的稳定和高效运行。同时,要不断关注 Redis 缓存特性的发展和变化,及时调整策略,以应对不断出现的新挑战。
52 10
|
15天前
|
Web App开发 缓存 UED
如何设置浏览器的缓存策略?
【10月更文挑战第23天】通过合理地设置浏览器的缓存策略,可以在提高网页性能、减少网络流量的同时,确保用户能够获取到最新的内容,从而提升用户体验和网站的性能优化效果。
52 4
|
16天前
|
存储 消息中间件 缓存
缓存策略
【10月更文挑战第25天】在实际应用中,还需要不断地监控和调整缓存策略,以适应系统的变化和发展。
|
19天前
|
缓存 监控 NoSQL
Redis 缓存穿透及其应对策略
【10月更文挑战第23天】通过以上对 Redis 缓存穿透的详细阐述,我们对这一问题有了更深入的理解。在实际应用中,我们需要根据具体情况综合运用多种方法来解决缓存穿透问题,以保障系统的稳定运行和高效性能。同时,要不断关注技术的发展和变化,及时调整策略,以应对不断出现的新挑战。
41 4
|
23天前
|
存储 缓存 NoSQL
保持HTTP会话状态:缓存策略与实践
保持HTTP会话状态:缓存策略与实践
|
1月前
|
存储 缓存 监控
|
1月前
|
缓存 分布式计算 NoSQL
大数据-47 Redis 缓存过期 淘汰删除策略 LRU LFU 基础概念
大数据-47 Redis 缓存过期 淘汰删除策略 LRU LFU 基础概念
62 2
|
2月前
|
缓存 JavaScript 中间件
优化Express.js应用程序性能:缓存策略、请求压缩和路由匹配
在开发Express.js应用时,采用合理的缓存策略、请求压缩及优化路由匹配可大幅提升性能。本文介绍如何利用`express.static`实现缓存、`compression`中间件压缩响应数据,并通过精确匹配、模块化路由及参数化路由提高路由处理效率,从而打造高效应用。
149 10