`
snoopy7713
  • 浏览: 1155618 次
  • 性别: Icon_minigender_2
  • 来自: 火星郊区
博客专栏
Group-logo
OSGi
浏览量:0
社区版块
存档分类
最新评论

Hibernate性能优化要点

阅读更多

Hibernate性能优化要点:

1.尽量使用many-to-one,避免使用单项one-to-many
2.灵活使用单向one-to-many
3.不用一对一,使用多对一代替一对一
4.配置对象缓存,不使用集合缓存
5.一对多使用Bag 多对一使用Set
6.继承使用显示多态  HQL:from object  polymorphism="exlicit" 避免查处所有对象
7.消除大表,使用二级缓存
    对于上面这些,有前辈进行了详细的讲解,在此转载,非常感谢前辈的总结。
one-to-many:
     使用inverse=false(default),对象的关联关系是由parent对象来维护的
     而inverse=true的情况下,一般用户双向多对多关联,由子对象维护关联关系,增加子对象的时候需要显示:child.setParent(child)
     为了提高性能,应该尽量使用双向one-to-many inverse=true,在MVC结构中的DAO接口中应该直接用Session持久化对象,避免通过关联关系(这句话有点不理解),而在单项关系中正确使用二级缓存,则可以大幅提高以查询为主的应用。
     多对一性能问题比较少,但是要避免经典N+1问题。
     通过主键进行关联,相当于大表拆分小表。(这个是区分面向对象设计和面向过程设计的一个关键点)
list、bag、set的正确运用
     one-to-many:
     A、使用list 需要维护Index Column字段,不能被用于双向关联,而且必须使用inverse=false,需要谨慎使用在某些稀有场合(基本上是不予考虑使用)
     B、bag/set在one-to-many中语义基本相同,推荐使用bag
     many-to-one:
     A、bag和set不同,bag允许重复插入,建议使用set
在庞大的集合分页中应该使用session.createFilter
    session.createFilter(parent.getChildren(),""),setFirstResult(0),setMaxResult(10))
避免N+1

    在多对一的情况下,查询child对象,当在页面上显示每个子类的父类对象的时候会导致N+1次查询,需要采用下面的方法避免:many-to-one fetch="join|select"(该方法可能有问题,参考http://www.iteye.com/post/266972

inverse=true 无法维护集合缓存(还不是很理解集合缓存和对象缓存)
OLTP类型的web应用,可以群集水平扩展,不可避免的出现数据库瓶颈
    框架能降低访问数据库的压力,采用缓存是衡量一个框架是否优秀的重要标准,从缓存方面看Hibernate
    A、对象缓存,细颗粒度,是针对表的级别,透明化访问,因为有不改变代码的好处,所以是ORM提高性能的法宝
    B、Hibernate是目前ORM框架中缓存性能最好的框架
    C、查询缓存
 针对大家经常出现的Hibernate vs iBatis的讨论进行了一个总结:
   对于OLTP应用,使用ORM框架 而OLEB应用(不确定是什么应用)最好采用JDBC或者其他方法处理
   Hibernate倾向于细颗粒度设计,面向对象,将大表拆分为多个小表,消除冗余字段,通过二级缓存提升性能。
  iBatis倾向于粗颗粒度设计,面向关系,尽量把表合并,通过Column冗余,消除关联关系,但是iBatis没有有效的缓存手段。

分享到:
评论

相关推荐

    Hibernate程序性能优化的考虑要点

    ### Hibernate程序性能优化的考虑要点 在开发基于Hibernate框架的应用时,性能优化是至关重要的环节。Hibernate作为一款优秀的对象关系映射(ORM)工具,它能够简化Java应用程序与数据库之间的交互,但不当的配置和...

    hibernate 优化

    以上是对Hibernate优化的一些核心要点,实践中还需要结合具体项目进行细致调整。理解Hibernate的工作机制,结合源码分析,可以更有效地找到性能瓶颈并进行优化。同时,利用工具如Profiler进行性能检测,可以帮助我们...

    hibernate配置要点详谈

    ### Hibernate配置要点详谈 #### 一、配置文件与配置方式 在Hibernate中,有两种主要的配置文件形式:`hibernate.cfg.xml` 和 `hibernate.properties`。 1. **`hibernate.cfg.xml`**: - 这种配置文件通常包含...

    hibernate和spring技术难点及其要点总结

    1. **性能优化**:如缓存管理、批处理、懒加载和集合初始化的控制。 2. **级联操作**:理解如何正确配置和使用对象间的关联级联操作。 3. **延迟加载**:理解何时启用和避免“懒加载”引发的N+1查询问题。 综上所述...

    db2 性能优化--最新整理

    ### DB2性能优化详解 #### 一、引言 在数据库管理系统(DBMS)领域,IBM的DB2作为一款成熟且...希望本文的内容能够帮助读者更好地理解DB2性能优化的核心要点,并在实际工作中灵活运用这些知识来提升系统的整体表现。

    java之hibernate和spring技术难点及其要点总结

    ### Java之Hibernate和Spring技术难点及其要点总结 #### Hibernate与Spring技术概述 在Java开发领域,Hibernate和Spring作为两个非常重要的框架,对于提高应用程序的开发效率、降低维护成本具有不可替代的作用。...

    hibernate_release_5.0.12.zip

    在性能优化方面,5.0.12版本引入了更高效的缓存策略。第二级缓存(Second-Level Cache)和查询缓存(Query Cache)得到了改善,可以减少数据库的访问次数,提高系统响应速度。此外,这个版本还优化了事务处理和并发...

    hibernate中文参考文档.pdf

    ### 性能优化 Hibernate提供了多种机制来优化数据库操作性能,例如二级缓存、懒加载和批量插入等。合理利用这些机制,可以显著减少数据库交互次数,提高应用的响应速度和整体性能。 ### 社区与文档 Hibernate拥有...

    马士兵Hibernate文档

    ### 性能优化 为了提高Hibernate应用的性能,可以通过以下几种方式进行优化: - 使用二级缓存来减少对数据库的访问次数。 - 合理设置fetch模式,减少不必要的关联查询。 - 使用batch处理和延迟加载等技术减少网络...

    Hibernate Recipes

    3. **查询与检索**:涵盖各种查询方式(如HQL、Criteria API等),以及如何优化查询性能。 4. **高级特性**:探讨Hibernate的一些高级特性,比如缓存机制、事务处理等。 5. **错误处理与调试**:提供常见的错误处理...

    Hibernate 源代码及重要说明

    3. **缓存机制**: Hibernate支持一级缓存(Session级别的缓存)和二级缓存(SessionFactory级别的缓存),优化了数据库访问性能。 4. **事件监听器**: Hibernate允许通过实现特定接口注册事件监听器,对对象的生命...

    2017黑马程序员第一天Hibernate讲义,笔记,源码

    以上知识点只是Hibernate框架的一部分,实际的讲义和笔记可能会涵盖更多细节,如性能优化、复杂查询、CGLIB和JPA集成等内容。源代码示例则会进一步帮助学习者将理论知识转化为实践技能。在学习这些资料时,应结合...

    hibernate3.2.4 源代码

    通过分析hibernate-3.2.4-src中的源代码,我们可以了解到Hibernate的架构设计、内部工作流程,以及如何优化性能。这将对提升Java开发者在ORM领域的专业技能有很大帮助,同时也为调试和解决实际项目中的问题提供参考...

    STRUTS+SPRING+HIBERNATE练习(完整).rar

    6. **完整**:"完整"一词可能意味着这个教程不仅涵盖了基本的集成步骤,还可能涉及了实际应用场景,如错误处理、性能优化、安全设置等方面,旨在提供一个可运行的、完整的示例项目。 以上是关于Struts、Spring和...

    Java Persistence With Hibernate(2008)

    - **性能优化:** 通过对查询执行方式的选择、缓存策略的应用以及事务管理的调整等手段,可以有效提升Hibernate应用程序的运行效率。 ##### 5. 查询语言与检索 - **HQL与Criteria API:** Hibernate提供了两种主要...

    无废话Hibernate技术实用笔记

    - 实现性能优化机制,如缓存和延迟加载。 4. **Hibernate的角色** - Hibernate是一个中间件,位于应用程序和数据库之间,简化了数据库访问。 - 它是一个持久化工具,隐藏了与数据库交互的复杂性,让开发者更专注...

    hibernate详细官方中文教程

    #### 六、性能优化 - **缓存策略**:合理设置缓存级别和策略,可以显著提升应用性能。 - **批处理**:使用批量处理减少数据库交互次数,提高整体效率。 - **SQL 优化**:根据实际场景调整 SQL 查询语句,避免不必要...

    Pro Hibernate 3 2005

    8. **性能调优**:提供了关于如何优化Hibernate应用性能的一系列建议,包括查询优化、连接池配置等。 9. **集成测试**:介绍了如何将Hibernate与JUnit等测试框架结合使用,确保代码质量。 10. **扩展与定制**:探索...

    hibernate 3.5.0-final core reference 中文pdf

    - **JMX整合**:讨论了如何通过JMX监控Hibernate的性能。 - **对JCA的支持**:解释了Hibernate如何支持Java Connector Architecture (JCA),以实现与外部资源的集成。 - **上下文相关的会话(Contextual Session)**...

Global site tag (gtag.js) - Google Analytics