`
zznj1123
  • 浏览: 123216 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

基于hibernate缓存机制的查询性能优化研究(三)

阅读更多

应用程序中必须在查询执行之前,将Query.Cacheable设置为true,而且每次都应该这样。比如:
  ………
  Query query=session.createQuery(hql).setInteger(0.15);
  query.setCacheable(true);
  ………
  但是,Query Cache只在特定的条件下才会发挥作用,而且要求相当严格:
  (1)完全相同的Select SQL重复执行。
  (2)重复执行期间,Query Key对应的数据表不能有数据变动(比如添、删、改操作)。
  并且,查询缓存在一个交易系统(数据变更频繁,查询条件相同的机率并不大)中可能会起反作用:它会白白耗费大量的系统资源但却很难发挥优势。
  2.2 数据查询方法的选用
  完成同样的查询,Hibernate提供了可供选择的一些方式,但具体使用什么方式,可能对性能和代码都会有影响。
  (1)Session.load/get方法均可以根据指定的实体类和id从数据库读取记录,并返回与之对应的实体对象。
  (a)Session. load
  在执行session.load时,Hibernate首先从当前session的一级缓存中获取id对应的值,在获取不到的情况下,将根据该对象是否配置了二级缓存来做相应的处理,如配置了二级缓存,则从二级缓存中获取id对应的值,如仍然获取不到则还需要根据是否配置了延迟加载来决定如何执行,如未配置延迟加载则从数据库中直接获取,在从数据库获取到数据的情况下,Hibernate会相应的填充一级缓存和二级缓存,如配置了延迟加载则直接返回一个代理类,只有在触发代理类的调用时才进行数据库查询的操作。如果未能发现符合条件的记录, load方法会抛出一个ObjectNotFoundException。
  (b)Session.get
  在执行Session.get时,和Session.load不同的就是get方法则仅仅在内部缓存中进行数据查找,如没有发现对应数据,将越过二级缓存,直接调用SQL完成数据读取。直接从数据库中获取id对应的值。如果未能发现符合条件的记录返回null,而且get方法永远直接返回实体类。
  (2)Query.list / Query.iterate方法均可根据指定条件查询并返回符合条件的实体对象集。
  (c)Query.list
  在执行Query.list时,Hibernate的做法是首先检查是否配置了查询缓存,如配置了则从查询缓存中通过一条sql语句获取所有符合条件的记录,并构造相应的实体对象,然后将其纳入缓存。如获取不到则从数据库中进行获取,从数据库获取到后Hibernate将会相应的填充一级、二级和查询缓存,如获取到的为直接的结果集,则直接返回,如获取到的为一堆id的值,则再根据id获取相应的值(Session.load),最后形成结果集返回。
  (d)Query.iterate
  在执行Query.iterate时,和Query.list的不同的在于从数据库获取的处理上,Query.iterate向数据库发起的是 select id from这样的语句,也就是它是先获取符合查询条件的id,之后在进行iterate.next调用时才再次发起session.load的调用获取实际的数据。iterate方法首先在本地缓存中根据id查找对应的实体对象是否存在(类似Session.load方法),如果缓存中已经存在对应的数据,则直接以此数据对象为查询结果,如果没有找到,再执行相应的Select语句获得对应的库表记录。(iterate方法如果执行了数据库读取操作并构建了完整的数据对象,也会将其查询结果纳入缓存)。
  而且,通过iterate,配合缓存管理API,在海量数据查询中可以很好的解决内存问题,如:
  while(it.hasNext()){
  YouObject object = (YouObject)it.next();
  session.evict(youObject);
  sessionFactory.evice(YouObject.class, youObject.getId());}
  如果用list方法,很可能就出OutofMemory错误了。
  可见,在拥有二级缓存并且查询参数多变的情况下,Query.iterate、Session. load会比Query.list及Session.get更为高效。
  
  3 结束语
  
  在实际开发中,运用好缓存可以让系统性能得到良好的提升。可缓存也有它的局限性,什么情况用什么情况不用,都要结合实际情况来考量。很多时候我们是在效率与安全/准确性上找一个平衡点,无论如何,优化都不是一个纯技术的问题,应该对应用和业务特征有足够的了解,如果违背了相关的缓存机制,可能会得到负面效果,所以必须充分考虑实际情况来灵活运用缓存并发挥它的优势。

分享到:
评论

相关推荐

    HIBERNATE的缓存机制

    Hibernate缓存机制是提高应用程序性能的关键特性,尤其是在频繁与数据库交互的应用中。缓存通过减少对物理数据库的直接访问次数,显著提升了数据读取和写入的速度。这主要是因为从缓存中读取数据比从数据库中获取更...

    基于数据库缓存的Web应用性能优化解决方案.pdf

    传统的Hibernate缓存机制基于查询条件将对象或查询结果缓存起来,但这种做法在数据发生变化时会迅速失效,导致缓存命中率低。为了克服这个局限,本文提出的方案采用了更灵活的缓存管理机制: 1. **一级缓存**:...

    hibernate缓存机制分析共17页.pdf.zip

    《Hibernate缓存机制详解》 Hibernate,作为Java领域中广泛使用的对象关系映射(ORM)框架,极大地简化了数据库操作。其缓存机制是优化性能的关键组成部分,它减少了对数据库的直接访问,提高了数据处理效率。本文...

    Hibernate一级缓存、二级缓存以及查询缓存实例

    在Java的持久化框架Hibernate中,缓存机制是优化数据库操作性能的重要手段。本文将深入探讨Hibernate的一级缓存、二级缓存以及查询缓存,通过具体的实例来阐述它们的工作原理和使用方法。 首先,我们从一级缓存开始...

    Hibernate的缓存级联查询

    总的来说,尽管Hibernate的使用场景可能不像过去那么广泛,但其提供的对象关系映射、缓存机制和查询优化策略仍然是理解现代数据库操作和Java开发中的宝贵知识。了解并掌握这些技术,可以帮助开发者编写出更高效、更...

    4.Hibernate-04查询以及优化策略1

    这些缓存机制可以显著地提高查询性能。 4.2 优化 HQL 查询 HQL 查询可以通过使用索引、限制查询范围和使用 Lazy Initialize 来优化。 4.3 优化 SQL 查询 SQL 查询可以通过使用索引、优化 SQL 语句和使用分页查询...

    hibernate缓存机制

    Hibernate缓存机制是提高应用程序性能的关键技术之一,它通过存储数据副本减少对数据库的直接访问。缓存分为两层:第一级缓存和第二级缓存。 第一级缓存是Hibernate的Session缓存,它是内置的,无法卸载,因此被...

    Hibernate缓存机制

    ### Hibernate缓存机制详解 #### 一、Hibernate缓存机制原理及配置 **1.1 Hibernate缓存概述** Hibernate作为一款流行的Java持久层框架,其缓存机制是提高应用程序性能的关键之一。缓存的主要作用在于减少数据库...

    Hibernate的缓存机制.docx

    Hibernate的缓存机制是优化数据库访问性能的关键组成部分。在Hibernate中,缓存主要分为三个层次:一级缓存、二级缓存以及集群范围的缓存。 一级缓存,也称为Session缓存,存在于单个Session实例中。其目的是减少对...

    Hibernate的缓存机制

    Hibernate 是一个流行的 Java 框架,用于简化对象关系映射(ORM)处理,它提供了一种高效的数据缓存机制,以提高应用程序的性能。本文将深入探讨 Hibernate 的缓存机制,包括其两个级别——一级缓存和二级缓存,并...

    基于Hibernate的在线考试优化设计与实现

    通过对在线考试系统进行基于Hibernate的优化设计与实现,可以有效地解决高并发情况下系统性能的问题。利用数据库连接池技术和Hibernate二级缓存机制,不仅能够提高系统的响应速度和稳定性,还能够显著提升用户体验。...

    铁路客票系统中缓存机制的应用模型研究.pdf

    通过深入研究Hibernate缓存机制,并结合铁路客票系统的业务特性,构建适合的缓存应用模型,可以显著提高售票速度,提升旅客满意度。同时,还需要持续关注和解决缓存应用中可能出现的问题,以确保系统的稳定性和高...

    hibernate 缓存机制

    Hibernate的缓存机制是优化应用程序性能的关键组成部分,它通过存储数据副本减少对数据库的直接访问,从而提升系统响应速度。缓存主要分为两类:一级缓存(Session缓存)和二级缓存。 一级缓存是Hibernate的核心...

    Hibernate教程25_Hibernate缓存

    **标题解析:** "Hibernate教程25_Hibernate缓存" 这个标题表明了我们要讨论的是关于Hibernate框架的第25个教程,重点是它的缓存机制。Hibernate是一个流行的Java对象关系映射(ORM)框架,它允许开发者用面向对象的...

    基于Hibernate的效率查询的研究和应用.pdf

    ### 基于Hibernate的效率查询的研究和应用 #### 摘要 本文详细探讨了当前流行的Hibernate映射框架,并结合某通信企业的电子运行维护系统(E2OMS)的实际开发过程,提出了一个基于Hibernate的数据持久层解决方案。该...

    Hibernate一级缓存和二级缓存

    描述中提到的链接可能是对Hibernate缓存机制的详细技术博客,但具体内容未给出。因此,我们将基于常规的Hibernate缓存知识进行解释。 **一、Hibernate一级缓存** 一级缓存是每个Hibernate Session内的缓存,它是一...

    hibernate缓存解析

    总结,Hibernate缓存机制是提升系统性能的重要手段,通过一级缓存减少数据库交互,二级缓存提供跨Session的数据共享,查询缓存则进一步优化了重复查询的效率。理解和充分利用这些缓存策略,能有效优化基于Hibernate...

    Hibernate缓存管理.doc

    【Hibernate缓存管理】是数据库持久化框架Hibernate中优化性能的关键技术。缓存的主要目的是减少对数据库的直接访问,提高应用程序...理解并有效利用Hibernate缓存机制,能显著提升数据库操作的性能,减少数据库负载。

    详解Hibernate缓存与性能优化

    总结来说,Hibernate的缓存机制是性能优化的重要手段。合理利用一级缓存、二级缓存和查询缓存,可以显著减少数据库访问,提高数据读取速度,从而提升整体应用性能。然而,缓存并非万能,过度依赖缓存可能导致数据...

    hibernate缓存.txt

    ### Hibernate缓存机制...通过本文的介绍,我们可以了解到Hibernate缓存机制的强大之处,特别是在配合Ehcache使用时,能够显著提升应用程序的性能。理解并合理配置这些缓存策略,对于构建高效稳定的应用程序至关重要。

Global site tag (gtag.js) - Google Analytics