|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
比如模式、敏捷方法什么的,这些思想好,但是实施的人没有理解而且没有正确运用这些知识导致了开发周期的延长。比如说对象,通过getName()方法不能获取对象的名字。进修了一段工夫的ibatis,我以为hibernate有着ibatis没法替换的上风。
1、开辟者都晓得,hibernate让我们以oo的体例操纵数据库,这让我们看到了hibernate的壮大的地方,体验到操纵数据的便利。但GavinKing说,hibernate最刺眼的地方是hibernate的缓存机制,而不是以oo的体例操纵数据库。Hibernate的缓存机制不过乎是一级缓存session,二级缓存sessionFactory,和第三方缓存如ehcache。也就是hibernate的最壮大的中央是它的缓存,了解了这个才干真实的了解hibernate。缓存其实太难了,我至今未能真正了解。
2、可保护性:ibatis宣传写sql语句,它将sql语句放进一个独自的xml文件,这类体例博得了良多开辟者的喜好,一句话,便利保护。但hibernate一样具有这类功效,并且比ibatis加倍壮大。Hibernate的定名查询/定名参数查询,就是将hql语句放在一个独自的xml文件当中,它仍旧让人们以面向对象的体例往利用数据,这失掉大批遵守oo体例开辟者的喜好,而不必在以oo的体例写着代码的同时,然后再变化头脑,用面向干系的体例往写那些sql语句。但hibernate不但做了这些,它的nativesql查询体例,完整满意sql语句的偏幸者,它像ibatis一样,将sql语句放在设置文件当中。
3、功能:我深信,hibernate功能成绩不是成绩。想一想那末多年夜中小项目都在利用hibernate,你还嫌疑hibernate的功能吗?spring整合hibernate以后,在真正功能瓶颈的中央,完整可使用spring集成的jdbc,或间接写存储历程得了。但起首得确认,这其实是功能瓶颈的中央,我想,不该想固然的以为功能的成绩,所谓的功能成绩拦阻了良多人。
我以为,功能的优劣无外是发送sql语句的几罢了。功能好,发送的sql语句少,功能差,就是发送大批的sql语句。Hibernate在办理功能成绩方面做得十分好。
有了它的缓存机制,利用第三方缓存和数据库毗连池,就较好的办理的功能成绩。
但这些还不敷,hibernate给了开辟者充足的自在,闪开发者本人往把持功能成绩。
我以为开辟者能够在以下几个方面自行调优:
a、在查询字符串中,应当老是利用jdbc的占位符?,或利用利用定名参数:,不要自查询中利用字符串值来取代十分量值。
b、Flush会影响功能,频仍革新影响功能,只管削减不用要的革新。
c、Cascade战略,在几对几的干系,准确设置cascade战略,想分明在操纵对象A的同时是不是必要级联操纵对象B,好比在onetomany的父子干系中,删除父亲one,需级联删除子many,这时候的one这端可设置cascade=“delete”,如许在删除one时,会主动删除子,但对子的操纵不会影响父。Cascade另有其他的属性值,只需设置准确,可提拔功能。
d、lazy战略,准确设置提早加载战略一样会提拔功能,在onetomany或manytomany中,一般总应当提早加载many的一方的到内存。设置了lazy=“true”,起首发送sql语句,加载本人到内存,到必要时才加载级联对象;lazy=”false”,则会同时加载本人和级联对象到内存。
e、别的另有汇合的功能(set、list、map、array),都应准确设置。
f、准确利用第三方缓存,在读操纵频仍写操纵未几的情形,利用第三方缓存可年夜幅度提拔功能,如ehcache的缓存战略有:read-only,read-write和notstrict-read-write。
f、跟着hibernate新版本的公布,和手艺的开展,我信任hibernate的功能会愈来愈好,一切功能不是不利用hibernate的缘故原由。
4、hibernate不单单作为耐久层的orm框架存在,它除dao层的耐久化操纵外,另有良多。
在注解annotation已走向支流的明天,hibernate敏捷呼应,让xml部署形貌符成为可选的。Hibernateannotation对年夜字段的处置只是一个@Lob就弄定了。
hibernatesearch对Lucene举行了轻量级的封装,全文检索变得十分复杂。
Hibernatevalidator被以为是最公道的考证体例,将考证战略间接附在贯串各层的范畴模子domain上,不再必要哪些web框架的xml体例的考证,代码中不再呈现大批的非空/null的判别。
5、jbpm,Jbpm营业流程引擎的耐久层接纳hibenrnate来完成,要想利用jbpm,hibernate是必需的。我想,营业流程办理非常主要,在soa敏捷开展的明天,假如实行soa项目,营业流程办理是一定和必需的。由于soa就是营业和it手艺的交融,是营业流程办理和it基本架构的交融。在soa中,营业办理是第一名的,这必要响应的手艺来完成该营业流程办理。开源范畴的jbpm我想会是首选。以是,为了未来有大概实行soa项目,为了完成soa的营业流程办理,应当利用hibernate。
6、人人都晓得,hibernate将ejb2时期的实体bean赶进了汗青,而ejb3的jpa尺度也只不外是hibernate的子集罢了。jsr标准哀求的能力是伟大的,没有各类jsr标准哀求,就不会有各类使用程序框架,各类使用程序框架只是那些jsr标准哀求的完成者。jpa作为耐久层的标准尺度,引诱耐久层orm框架的偏向,jpa一样以面向对象的体例操纵数据库,而不是写sql语句。标准尺度都完整orm,不写sql了,你另有来由不随着它吗?
7、Spring+hibernate+范型+可变参数,这是一个十分壮大的组合,对应一般的crud操纵,你不再必要反复写那些烦人的类似的dao层和manager层的代码,仅仅必要写一次,就完成了一切大批的crud操纵。Ibatis只管也撑持范型,但一直没有hibernate撑持的好
8、Jboss,hibernate是jboss的项目,jboss的一切项目标耐久层都接纳的hibernate,要晓得,jsr标准组的专家们年夜多半是来自jboss的,在必定水平上说,jboo引领着java的开展偏向。利用hibernate,随着jboss,不偏离java的开展偏向。
9、GavinKing,我最崇敬的偶像,他不但创造了壮大的hibernate,还弄出了一样壮大且文雅的web2.0使用程序框架seam。他是ejb3.0专家构成员之一,是jpa标准哀求的向导者,他java范畴最有讲话权、最威望的首脑人物之一。如今,他向导webbean的,jsr299的开展,webbean标准的制订,环球软件巨子如ibm、oracle、bea和apache没有一个否决,纷繁呼应。Webbean,设想起来,其实太优美了,完整的松耦合和强范例,一切的使用组件生存在一个使用组件高低文context中,互相互助。当时将不再有林林总总的高低文情况,不再有struts2的ActionContext,不再有spring的ApplicationContext,不再有hibernate的session,不再有耐久化高低文,不再有事件高低文,不再有平安高低文,一切组件生存在一个小家庭中,人人其乐陶陶,完成世界的年夜战争。
10、osgi,我以为如今最值得进修的一个手艺,有了osgi,完成真实的多模块开辟,改动传统的开辟体例。如今,已有了hibernateosgi,springdynamicmodul(osgi),struts2一样完成了对osgi的撑持。今朝,eclipse是基于osgi开辟的,ibm的webspherev6.1,bea的一切产物都重构在osgi上,spring的使用服务器一样基于osgi,在EclipseCon2007上,osgi成了次要的话题。Osgi遭到云云的报酬,一点不奇异,由于他具有没有比壮大的功效,改动传统的软件开辟体例。Osgi接纳树计划形式,将一个项目分红多个模块(bundle),每一个模块独自部署,独自运转,说白了,就是将一个工程分红很多的插件,每一个插件独自开辟,反复利用,完成完整的即插即用。太使人冲动了。假如公司的软件开辟基于osgi,将会有大批的反复利用的osgibundles,公司将会堆集大批的有形资产,软件开辟将会愈来愈快。而ibatis如今还没见到对osgi的撑持。
11、hibernate的社区十分昌盛,ibatis则绝对僻静。
综述,hibernate另有良多优异的特性,只是我们不晓得。Hibernate与ibatis,就像人人闺秀对小家碧玉,人人闺秀不但具有小家碧玉的全体,并且出名度更高,更受尊崇,更受人追捧,更有开展出路。小家碧玉只管也很有魅力,但一直比上人人闺秀。
Hibernate所做的不单单是dao层的耐久化事情,而ibatis恰好云云。
选择hibernate,选择orm的王者,选择更周全的事情体验,选择更高效的事情体例,选择更多的利润;选择GavinKing,随着首脑走;选择jboss,跟随开源的潮水,不偏离java的开展偏向。
统统都不是托言。统统都在开展,hibernate会愈来愈好。
来自:利用hibernate的11年夜上风
先说优点,首先和C,C++这些语言比起来,java很简单,去掉指针的java,非常好理解,自动垃圾回收机制也很好,自从JDK1.5推出以后,性能上又有了很大提高。 |
|