`

最全面的Hibernate 性能优化技巧

阅读更多

 

 

 

 

http://www.dukai168.cn/blog/165.html

hibernate的性能被无数开发人员质疑,又被无数开发人员称赞,是是非非,到底是怎么样的呢?性能的优化在hibernate的无数教程中已经给出,但是实际开发中,开发人员很难一一去注意怎么去提升hibenate的性能。在此leo给出目前最全面的Hibernate 性能优化技巧. 1) 在处理大数据量时,会有大量的数据缓冲保存在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_size,hibernate.jdbc.batch_size等属性,对Hibernate进行优化。 9) 不过值得注意的是,一些数据库提供的主键生成机制在效率上未必最佳,大量并发insert数据时可能会引起表之间的互锁。数据库提供的主键生成机制,往往是通过在一个内部表中保存当前主键状态(如对于自增型主键而言,此内部表中就维护着当前的最大值和递增量),之后每次插入数据会读取这个最大值,然后加上递增量作为新记录的主键,之后再把这个新的最大值更新回内部表中,这样,一次Insert操作可能导致数据库内部多次表读写操作,同时伴随的还有数据的加锁解锁操作,这对性能产生了较大影响。 因此,对于并发Insert要求较高的系统,推荐采用uuid.hex 作为主键生成机制。 10) Dynamic Update 如果选定,则生成Update SQL 时不包含未发生变动的字段属性,这样可以在一定程度上提升SQL执行效能.Dynamic Insert 如果选定,则生成Insert SQL 时不包含未发生变动的字段属性,这样可以在一定程度上提升SQL执行效能 11)在编写代码的时候请,对将POJO的getter/setter方法设定为public,如果设定为private,Hibernate将无法对属性的存取进行优化,只能转而采用传统的反射机制进行操作,这将导致大量的性能开销(特别是在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进行数据库操作时的效率。通常,性能优化涉及减少延迟、提高吞吐量、降低资源消耗等...

    Java性能优化技巧集锦

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

    Hibernate程序性能优化.doc

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

    hibernate 持久层优化

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

    Jboss性能优化整合

    《JBoss性能优化整合》是一份深度探讨Jboss应用服务器性能提升的重要资料,它集结了作者反复试验与研究的心得,旨在为读者提供实用而全面的优化策略。Jboss作为一款开源的企业级Java应用服务器,其性能表现直接影响...

    hibernate教程打包下载,史上最全的HIBERNATE

    10. **性能优化**:教程可能涵盖如何优化Hibernate,例如批量操作、延迟加载、缓存策略调整、避免N+1查询问题等。 11. **实例分析**:通过实际项目案例,演示如何在Web应用(如Spring Boot)中整合Hibernate,解决...

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

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

    Hibernate性能调优

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

    hibernate优化前的程序

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

    hibernate优化

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

    SSH架构性能优化方案.pdf

    在J2EE平台架构中,性能优化是至关重要的,尤其是对于大规模并发访问的应用系统。SSH架构,即Struts、Spring和Hibernate的组合,是Java Web开发中的常见选择。本篇文档将聚焦于SSH架构的服务器端性能优化,探讨如何...

    hibernate性能调节

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

    精通Hibernate(孙卫琴)

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

    hibernate 电子书全集

    6. **性能调优**:针对大数据量和高并发场景的性能优化技巧。 7. **最新版本特性**:涵盖Hibernate的最新更新和改进。 《hibernate中文参考文档》提供了详细的API文档和使用指南,是开发者在编程过程中不可或缺的...

    Java面试题集(最全版) (1)(1).doc

    Java面试题集知识点总结 Java面试题集是Java开发者面试准备的重要资源,该文档涵盖了Java...* Hibernate性能优化建议:Hibernate性能优化的建议,包括Hibernate配置优化、Hibernate SQL优化、Hibernate索引优化等。

    传智播客李勇hibernate PPT

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

    精通Hibernate+源代码

    此外,书中还会涉及Hibernate的性能优化技巧,如延迟加载、批处理和连接池配置,这些都是实际项目中必不可少的知识。同时,作者可能还会讨论Hibernate与其他技术的集成,如Spring框架的整合,以及如何在分布式环境下...

    Hibernate电子书(全)

    延迟加载是一种优化技术,允许Hibernate在真正需要的时候才加载关联的对象,从而减少了不必要的数据库访问,提高了应用程序的性能。 #### Session管理 在Hibernate中,所有的数据操作都需要在一个Session的上下文中...

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

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

    hibernate 调优

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

Global site tag (gtag.js) - Google Analytics