- 浏览: 887406 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (687)
- java (127)
- servlet (38)
- struts (16)
- spring (22)
- hibernate (40)
- javascript (58)
- jquery (18)
- tomcat (51)
- 设计模式 (6)
- EJB (13)
- jsp (3)
- oracle (29)
- RUP (2)
- ajax (3)
- java内存管理 (4)
- java线程 (12)
- socket (13)
- path (5)
- XML (10)
- swing (2)
- UML (1)
- JBPM (2)
- 开发笔记 (45)
- Note参考 (15)
- JAXB (4)
- Quartz (2)
- 乱码 (2)
- CSS (2)
- Exception (4)
- Tools (7)
- sqlserver (3)
- DWR (7)
- Struts2 (47)
- WebService (2)
- 问题解决收藏 (7)
- JBOSS (7)
- cache (10)
- easyUI (19)
- jQuery Plugin (11)
- FreeMarker (6)
- Eclipse (2)
- Compass (2)
- JPA (1)
- WebLogic (1)
- powerdesigner (1)
- mybatis (1)
最新评论
-
bugyun:
受教了,谢谢
java 正则表达式 过滤html标签 -
xiongxingxing_123:
学习了,感谢了
java 正则表达式 过滤html标签 -
wanmeinange:
那如果无状态的。对同一个任务并发控制怎么做?比如继承Quart ...
quartz中参数misfireThreshold的详解 -
fanjieshanghai:
...
XPath 元素及属性查找 -
tianhandigeng:
还是没明白
quartz中参数misfireThreshold的详解
在处理大数据量时,会有大量的数据缓冲保存在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) 由于多对多关联的性能不佳(由于引入了中间表,一次读取操作需要反复数次查询),因此在设计中应该避免大量使用.
发表评论
文章已被作者锁定,不允许评论。
-
Criteria查询,DetachedCriteria离线查询 --做综合查询
2011-09-06 00:25 1597通过Session得到Criteria类的对象 Ja ... -
Hibernate批量操作(JDBC批量操作)
2011-09-06 00:24 1293部分内容转自 :http://ga ... -
Hibernate懒加载深入分析
2011-09-06 00:19 1324懒加载可以提高性能吗? 不可以简单的说"能" ... -
getSesson currentSession
2011-09-06 00:15 10001 getCurrentSession创建的session会和 ... -
Hibernate 操作Blob Clob
2011-09-05 23:46 1068Photo.java Java代码 i ... -
Hibernate建表错误,Could not determine type for: java.util.List
2011-04-04 22:19 1642今天遇到 Could not determine type f ... -
Hibernate的fetch="join"和fetch="select"
2011-03-24 14:16 969fetch参数指定了关联对 ... -
Hibernate的Criteria用法总结
2011-03-23 10:53 777最近在项目中使用 Struts 和 Hibernate 进行开 ... -
第29讲--为Spring集成的Hibernate配置二级缓存
2011-03-10 23:16 1101合理的使用缓存策略,往往在web开发中提高性能起到关键作用。 ... -
hibernate抓取策略
2011-02-12 13:23 820Hibernate最让人头大的就是对集合的加载形式。书看了N次 ... -
Hibernate笔记:HQL查询总结(一)——简单属性查询和实体对象查询
2011-02-01 23:38 3494本文一部分转自kuangbaoxu的博文hibernate-- ... -
Hibernate笔记:HQL查询总结(二)——条件查询
2011-02-01 23:35 1507条件查询 1.拼字符串 where条件后面,可以用字 ... -
Hibernate属性延迟加载
2011-02-01 21:28 1012Hibernate3开始增加了通过property节点的la ... -
Hibernate中的cascade和inverse
2011-01-31 00:31 994这两个属性都用于一多对或者多对多的关系中。而inverse特别 ... -
batch_size 和 fetch_size作用
2010-12-01 21:37 1280hibernate抓取策略,,batch-szie在< ... -
hibernate中SQLQuery的addEntity();方法
2010-10-20 10:48 2770如果使用原生sql语句进行query查询时,hibernate ... -
Hibernate的evict方法错误总结
2010-10-14 10:08 1209摘自百度知道:http://zhi ... -
hibernate中get方法和load方法的区别
2010-10-14 09:57 799键字: hibernate get load 区 ... -
Hibernate: 设A引用了B,则删A后可能要evict(A.getB())
2010-10-14 09:56 1001Hibernate: 设A引用了B,如果要先取A删A再取B删B ... -
Hibernate的flush()和evict()总结
2010-10-14 09:53 1324关键字: hibernate flush() evict() ...
相关推荐
"Hibernate性能优化共9页.pdf.zip" 这个文件标题表明了内容专注于Hibernate框架的性能优化,暗示我们将探讨如何提升使用Hibernate进行数据库操作时的效率。通常,性能优化涉及减少延迟、提高吞吐量、降低资源消耗等...
8. Hibernate性能优化技巧 9. 实际项目案例分析 通过这份读书笔记,读者将能全面理解Hibernate的工作机制,掌握其基本用法,并能够将其应用于实际的Java开发项目中。同时,对于源码部分的探讨,有助于深入理解...
### Hibernate程序性能优化 #### 一、概述 Hibernate作为一款流行的Java持久层框架,为开发者提供了简化数据库操作的强大工具。然而,在实际应用中,不少开发者遇到了性能问题:使用Hibernate实现的功能与直接使用...
以下是一些关键的Java性能优化技巧: 1. **避免使用`new`关键字创建对象**: 在创建类实例时,`new`关键字会触发构造函数链的调用,这可能会带来额外的开销。如果对象实现了`Cloneable`接口,可以使用`clone()`方法...
Hibernate 性能优化技巧 - **使用二级缓存** - 通过合理配置二级缓存,可以极大地提升应用程序的性能。 - **优化 SQL 语句** - 通过调整 Hibernate 生成的 SQL 语句,避免不必要的数据检索。 - **懒加载** - 懒...
Hibernate 性能优化技巧 - **使用懒加载**:减少不必要的数据库查询。 - **合理设置缓存策略**:利用一级缓存和二级缓存提高效率。 - **优化查询**:减少不必要的查询,使用合适的查询方式。 ### 7. Struts 的...
#### 五、其他优化技巧 除了上述提到的方法外,还有一些其他的技巧可以帮助进一步优化Hibernate持久层的性能: 1. **事务管理**:合理配置事务边界,确保最小化不必要的数据库锁定时间。 2. **连接池配置**:正确...
8. **性能优化**:如批处理更新、延迟加载、预加载、查询优化等技巧,可以帮助提升应用程序的效率。 9. **Callback事件**:Hibernate支持实体类的生命周期回调,如@PrePersist、@PostLoad等注解,可以用于实现特定...
10. **其他优化技巧** - **延迟加载禁用**:在不需要的时候关闭延迟加载,避免加载无关对象。 - **开启二级缓存统计**:通过监控来发现潜在的性能问题。 以上是对Hibernate性能调优的一些关键点,实际应用中,还...
这份《JBoss性能优化整合》资料详尽阐述了以上各个方面的优化技巧,通过实践这些策略,开发者可以有效地提升Jboss的性能,从而构建出更加稳定、高效的业务系统。无论你是初学者还是经验丰富的开发者,都能从中获得...
SQL性能优化**:审查并调整生成的SQL,如添加索引、避免全表扫描、优化JOIN操作等。 **7. 事务管理**:合理设置事务边界,避免长时间持有事务,减少锁的使用。 总结来说,优化Hibernate程序需要从多个方面考虑,...
除此之外,还有其他优化技巧,如减少实体类的瞬态属性,使用代理类而非实体类进行查询,优化HQL和 Criteria查询,避免过多的实体继承,以及使用批量操作等。同时,确保数据库索引的合理设计也是提高性能的重要一环。...
《Hibernate性能调节》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,随着应用规模的扩大,性能优化成为开发者必须面对的问题。本文将深入探讨如何对Hibernate...
孙卫琴在书中分享了关于缓存策略(一级缓存和二级缓存)、延迟加载、批处理更新等提升Hibernate性能的技巧。同时,他还探讨了事务管理和并发控制,这些都是确保数据一致性和完整性的关键。 最后,书中的实战案例...
11. **性能优化**:分享一些提高Hibernate性能的策略,如合理设计实体关系、优化查询、使用批处理等。 12. **实战案例**:通过具体项目实例,演示如何在实际开发中运用Hibernate,包括项目结构设计、数据库设计、...
在J2EE平台架构中,性能优化是至关重要的,尤其是对于大规模并发访问的应用系统。SSH架构,即Struts、...理解这些基础优化技巧并结合实际情况灵活应用,可以显著提升SSH架构应用的性能,满足大规模并发访问的需求。
学习Hibernate3.3,需要关注性能优化技巧,例如延迟加载(Lazy Loading)、批处理(Batch Processing)、结果集缓存(Result Set Caching)、预加载(Preloading)等。理解并适时应用这些技术,可以在保证应用功能的...
1. **基本原则**:HQL(Hibernate Query Language)的优化技巧与普通 SQL 的优化技巧相似。例如,尽量避免使用 SELECT *,而是指定需要的字段;避免使用子查询和嵌套查询;合理使用索引等。 2. **缓存机制**:理解 ...
11. **性能优化注意事项**: 在实际应用中,应结合业务场景调整批处理大小,过大可能导致内存溢出,过小则可能无法充分利用数据库的批处理功能。 12. **监控与调优**: 使用数据库日志、监控工具(如JProfiler)或...
本书不仅是一本教程和参考指南,还深入介绍了如何开发和优化工业级别的Hibernate应用程序。作者们按照从简单到复杂的顺序逐步介绍概念,并通过丰富的实例来解释每一个细节。以下是本书覆盖的一些关键知识点: 1. **...