|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
java主要分三块,j2se:java的基础核心语言。j2me:java的微型模块,专门针对内存小,没有持续电源等小型设备。j2ee:java的企业模块,专门针对企业数据库服务器的连接维护。功能|优化 1、针对oracle数据库而言,FetchSize是设定JDBC的Statement读取数据的时分每次从数据库中掏出的纪录条数,一样平常设置为30、50、100。Oracle数据库的JDBC驱动默许的FetchSize=15,设置FetchSize设置为:30、50,功能会有分明提拔,假如持续增年夜,超越100,功能提拔不分明,反而会损耗内存。
即在hibernate配制文件中举行配制:
1<propertyname="hibernateProperties">
2<props>
3<propkey="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>
4<propkey="hibernate.show_sql">false</prop>
5<!--Create/updatethedatabasetablesautomaticallywhentheJVMstartsup
6<propkey="hibernate.hbm2ddl.auto">update</prop>-->
7<!--TurnbatchingoffforbettererrormessagesunderPostgreSQL
8<propkey="hibernate.jdbc.batch_size">100</prop>-->
9<propkey="hibernate.jdbc.batch_size">50</prop>
10</props>
11</property>FetchSize设的越年夜,读数据库的次数越少,速率越快;FetchSize越小,读数据库的次数越多,速率越慢。
2、假如是超年夜的体系,倡议天生htm文件。加速页面提拔速率。
3、不要把一切的义务推在hibernate上,对代码举行重构,削减对数据库的操纵,只管制止在数据库查询时利用in操纵,和制止递回查询操纵,代码质量、体系计划的公道性决意体系功能的上下。
4、对年夜数据量查询时,慎用list()大概iterator()前往查询了局,
(1).利用List()前往了局时,Hibernate会一切查询了局初始化为耐久化对象,了局集较年夜时,会占用良多的处置工夫。
(2).而利用iterator()前往了局时,在每次挪用iterator.next()前往对象并利用对象时,Hibernate才挪用查询将对应的对象初始化,关于年夜数据量时,每挪用一次查询城市消费较多的工夫。当了局集较年夜,可是含有较大批不异的数据,大概了局集不是全体城市利用时,利用iterator()才有上风。
5、在一对多、多对一的干系中,利用提早加载机制,会使很多的对象在利用时方会初始化,如许可以使得节俭内存空间和削减数据库的负荷,并且若PO中的汇合没有被利用时,便可削减互数据库的交互从而削减处置工夫。
6、对含有联系关系的PO(耐久化对象)时,若default-cascade="all"大概“save-update”,新增PO时,请注重对PO中的汇合的赋值操纵,由于有大概使很多实行一次update操纵。
7、关于年夜数据量新增、修正、删除操纵大概是对年夜数据量的查询,与数据库的交互次数是决意处置工夫的最主要要素,削减交互的次数是提拔效力的最好路子,以是在开辟过程当中,请将show_sql设置为true,深切懂得Hibernate的处置历程,实验分歧的体例,可使得效力提拔。尽量对每一个页面的显现,对数据库的操纵削减到100----150条之内。越少越好。
以上是在举行struts+hibernate+spring举行项目开辟中,对hibernate功能优化的几点心得。
微软什么都提供了。你可以试想一下,如果你是新手,你是希望你点一下按钮程序就能运行那,还是想自己一点一点的组织结构,然后打包发部,调错再打包...... |
|