`
esffor
  • 浏览: 1367419 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Hibernate 性能优化技巧

阅读更多
在处理大数据量时,会有大量的数据缓冲保存在Session的一级缓存中,这缓存大太时会严重显示性能,所以在使用Hibernate处理大数据量的,可以使用session.clear()或者session. Evict(Object) 在处理过程中,清除全部的缓存或者清除某个对象。

2)
对大数据量查询时,慎用list()或者iterator()返回查询结果,
1.
使用List()返回结果时,Hibernate会所有查询结果初始化为持久化对象,结果集较大时,会占用很多的处理时间。
2.
而使用iterator()返回结果时,在每次调用iterator.next()返回对象并使用对象时,Hibernate才调用查询将对应的对象初始化,对于大数据量时,每调用一次查询都会花费较多的时间。当结果集较大,但是含有较大量相同的数据,或者结果集不是全部都会使用时,使用iterator()才有优势。
3.
对于大数据量,使用qry.scroll()可以得到较好的处理速度以及性能。而且直接对结果集向前向后滚动。

3)
对于关联操作,Hibernate虽然可以表达复杂的数据关系,但请慎用,使数据关系较为简单时会得到较好的效率,特别是较深层次的关联时,性能会很差。

4)
对含有关联的PO(持久化对象)时,若default-cascade="all"或者 “save-update”,新增PO时,请注意对PO中的集合的赋值操作,因为有可能使得多执行一次update操作。

5)
在一对多、多对一的关系中,使用延迟加载机制,会使不少的对象在使用时会初始化,这样可使得节省内存空间以及减少数据库的负荷,而且若PO中的集合没有被使用时,就可减少互数据库的交互从而减少处理时间。

6) 对于大数据量新增、修改、删除操作或者是对大数据量的查询,与数据库的交互次数是决定处理时间的最重要因素,减少交互的次数是提升效率的最好途径,所以在开发过程中,请将show_sql设置为true,深入了解Hibernate的处理过程,尝试不同的方式,可以使得效率提升。

7) Hibernate是以JDBC为基础,但是Hibernate是对JDBC的优化,其中使用Hibernate的缓冲机制会使性能提升,如使用二级缓存以及查询缓存,若命中率较高明,性能会是到大幅提升。

8)Hibernate可以通过设置hibernate.jdbc.fetch_sizehibernate.jdbc.batch_size等属性,对Hibernate进行优化。
 
9) 不过值得注意的是,一些数据库提供的主键生成机制在效率上未必最佳,大量并发insert数据时可能会引起表之间的互锁。数据库提供的主键生成机制,往往是通过在一个内部表中保存当前主键状态(如对于自增型主键而言,此内部表中就维护着当前的最大值和递增量),之后每次插入数据会读取这个最大值,然后加上递增量作为新记录的主键,之后再把这个新的最大值更新回内部表中,这样,一次Insert操作可能导致数据库内部多次表读写操作,同时伴随的还有数据的加锁解锁操作,这对性能产生了较大影响。
因此,对于并发Insert要求较高的系统,推荐采用uuid.hex 作为主键生成机制。
 
10) Dynamic Update 如果选定,则生成Update SQL 时不包含未发生变动的字段属性,这样可以在一定程度上提升SQL执行效能.Dynamic Insert 如果选定,则生成Insert SQL 时不包含未发生变动的字段属性,这样可以在一定程度上提升SQL执行效能
 
11)在编写代码的时候请,对将POJOgetter/setter方法设定为public,如果设定为privateHibernate将无法对属性的存取进行优化,只能转而采用传统的反射机制进行操作,这将导致大量的性能开销(特别是在1.4之前的Sun JDK版本以及IBM JDK中,反射所带来的系统开销相当可观)。
 
12)one-to-many 关系中,将many 一方设为主动方(inverse=false)将有助性能的改善
 
13) 由于多对多关联的性能不佳(由于引入了中间表,一次读取操作需要反复数次查询),因此在设计中应该避免大量使用.
 
14) Hibernate支持两种锁机制:即通常所说的“悲观锁(Pessimistic Locking)”和“乐观锁(Optimistic Locking)”。悲观锁带来数据库性能的大量开销,特别是对长事务而言,这样的开销往往无法承受。乐观锁机制在一定程度上解决了这个问题.乐观锁机制避免了长事务中的数据库加锁开销,大大提升了大并发量下的系统整体性能表现。


 

分享到:
评论

相关推荐

    Hibernate性能优化共9页.pdf.zip

    "Hibernate性能优化共9页.pdf.zip" 这个文件标题表明了内容专注于Hibernate框架的性能优化,暗示我们将探讨如何提升使用Hibernate进行数据库操作时的效率。通常,性能优化涉及减少延迟、提高吞吐量、降低资源消耗等...

    hibernate 读书笔记

    8. Hibernate性能优化技巧 9. 实际项目案例分析 通过这份读书笔记,读者将能全面理解Hibernate的工作机制,掌握其基本用法,并能够将其应用于实际的Java开发项目中。同时,对于源码部分的探讨,有助于深入理解...

    Hibernate程序性能优化.doc

    ### Hibernate程序性能优化 #### 一、概述 Hibernate作为一款流行的Java持久层框架,为开发者提供了简化数据库操作的强大工具。然而,在实际应用中,不少开发者遇到了性能问题:使用Hibernate实现的功能与直接使用...

    Java性能优化技巧集锦

    以下是一些关键的Java性能优化技巧: 1. **避免使用`new`关键字创建对象**: 在创建类实例时,`new`关键字会触发构造函数链的调用,这可能会带来额外的开销。如果对象实现了`Cloneable`接口,可以使用`clone()`方法...

    heibernate面试题

    Hibernate 性能优化技巧 - **使用二级缓存** - 通过合理配置二级缓存,可以极大地提升应用程序的性能。 - **优化 SQL 语句** - 通过调整 Hibernate 生成的 SQL 语句,避免不必要的数据检索。 - **懒加载** - 懒...

    ssh面试题 txt文档

    Hibernate 性能优化技巧 - **使用懒加载**:减少不必要的数据库查询。 - **合理设置缓存策略**:利用一级缓存和二级缓存提高效率。 - **优化查询**:减少不必要的查询,使用合适的查询方式。 ### 7. Struts 的...

    hibernate 持久层优化

    #### 五、其他优化技巧 除了上述提到的方法外,还有一些其他的技巧可以帮助进一步优化Hibernate持久层的性能: 1. **事务管理**:合理配置事务边界,确保最小化不必要的数据库锁定时间。 2. **连接池配置**:正确...

    Hibernate使用技巧共2页.pdf.zip

    8. **性能优化**:如批处理更新、延迟加载、预加载、查询优化等技巧,可以帮助提升应用程序的效率。 9. **Callback事件**:Hibernate支持实体类的生命周期回调,如@PrePersist、@PostLoad等注解,可以用于实现特定...

    Hibernate性能调优

    10. **其他优化技巧** - **延迟加载禁用**:在不需要的时候关闭延迟加载,避免加载无关对象。 - **开启二级缓存统计**:通过监控来发现潜在的性能问题。 以上是对Hibernate性能调优的一些关键点,实际应用中,还...

    Jboss性能优化整合

    这份《JBoss性能优化整合》资料详尽阐述了以上各个方面的优化技巧,通过实践这些策略,开发者可以有效地提升Jboss的性能,从而构建出更加稳定、高效的业务系统。无论你是初学者还是经验丰富的开发者,都能从中获得...

    hibernate优化前的程序

    SQL性能优化**:审查并调整生成的SQL,如添加索引、避免全表扫描、优化JOIN操作等。 **7. 事务管理**:合理设置事务边界,避免长时间持有事务,减少锁的使用。 总结来说,优化Hibernate程序需要从多个方面考虑,...

    hibernate优化

    除此之外,还有其他优化技巧,如减少实体类的瞬态属性,使用代理类而非实体类进行查询,优化HQL和 Criteria查询,避免过多的实体继承,以及使用批量操作等。同时,确保数据库索引的合理设计也是提高性能的重要一环。...

    hibernate性能调节

    《Hibernate性能调节》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,随着应用规模的扩大,性能优化成为开发者必须面对的问题。本文将深入探讨如何对Hibernate...

    精通Hibernate(孙卫琴)

    孙卫琴在书中分享了关于缓存策略(一级缓存和二级缓存)、延迟加载、批处理更新等提升Hibernate性能的技巧。同时,他还探讨了事务管理和并发控制,这些都是确保数据一致性和完整性的关键。 最后,书中的实战案例...

    传智播客李勇hibernate PPT

    11. **性能优化**:分享一些提高Hibernate性能的策略,如合理设计实体关系、优化查询、使用批处理等。 12. **实战案例**:通过具体项目实例,演示如何在实际开发中运用Hibernate,包括项目结构设计、数据库设计、...

    SSH架构性能优化方案.pdf

    在J2EE平台架构中,性能优化是至关重要的,尤其是对于大规模并发访问的应用系统。SSH架构,即Struts、...理解这些基础优化技巧并结合实际情况灵活应用,可以显著提升SSH架构应用的性能,满足大规模并发访问的需求。

    Hibernate3.3_学习笔记.doc.zip

    学习Hibernate3.3,需要关注性能优化技巧,例如延迟加载(Lazy Loading)、批处理(Batch Processing)、结果集缓存(Result Set Caching)、预加载(Preloading)等。理解并适时应用这些技术,可以在保证应用功能的...

    hibernate 调优

    1. **基本原则**:HQL(Hibernate Query Language)的优化技巧与普通 SQL 的优化技巧相似。例如,尽量避免使用 SELECT *,而是指定需要的字段;避免使用子查询和嵌套查询;合理使用索引等。 2. **缓存机制**:理解 ...

    关于hibernate的批处理

    11. **性能优化注意事项**: 在实际应用中,应结合业务场景调整批处理大小,过大可能导致内存溢出,过小则可能无法充分利用数据库的批处理功能。 12. **监控与调优**: 使用数据库日志、监控工具(如JProfiler)或...

    hibernate实战 英文版

    本书不仅是一本教程和参考指南,还深入介绍了如何开发和优化工业级别的Hibernate应用程序。作者们按照从简单到复杂的顺序逐步介绍概念,并通过丰富的实例来解释每一个细节。以下是本书覆盖的一些关键知识点: 1. **...

Global site tag (gtag.js) - Google Analytics