熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Java編程 >> Java開源技術 >> 正文

Hibernate已經落伍了嗎?[1]

2013-11-23 20:48:45  來源: Java開源技術 
    在Java世界Hibernate是最引人關注的一個話題從Gavin King加入EJB EG負責制訂EJB的持久層規范到Gavin King非正式退出JDO EG並且充滿個人情緒的攻擊JDO規范到《Hibernate in Action》的發行再到Hibernate Alpha的發布最後再到最近JBoss PR的發布(使用Hibernate實現Entity Bean)可以說這其中的每一步都引起業界的側目

    Hibernate在不到年的時間裡從一個不起眼的開源軟件發展到今天令業界矚目的主流O/R Mapping框架Gavin King從一個開源軟件的作者成為業界舉足輕重的人物這多少有些傳奇的色彩畢竟單純從技術成就而言Hibernate不算是最有成就的Java開源框架軟件到目前為止也不是一個完美無缺的軟件從個人技術水平而言Gavin King也不算絕頂高手

    在當前的Java持久層框架中最流行的O/R Mapping產品分別是HibernateJDO和TopLink

    自從去年Gavin King加入JBoss之後Hibernate已經由一個民間的開源軟件走上了兼容EJB EntityBean的道路然而更加令人側目的是Gavin King在EJB EG中充當了一個非常重要的角色只要對比一下EJB的EntityBean和Hibernate真相就會大白雖然API接口不同但是 EntityBean的設計理念完全來自於Hibernate

    雖然EJB的EntityBean在相當程度上來源於Hibernate但是畢竟是不同的API接口因此Hibernate和EJB EntityBean究竟是怎樣的一種關系是很多人心中的疑問

    年四月份JBoss的Ben Wang訪華期間我曾經向Ben請教Hibernate的未來發展他回答說Hibernate未來將仍舊以獨立的軟件產品存在和發展既可以 outside EJB container使用同時Hibernate也將做為JBoss EntityBean Implementation又可以inside EJB container使用然而如何既inside又outside終究缺乏一個感性的認識

    日JBoss發布的 EJB PR揭開了答案從Sourceforge的CVS服務器上面checkout出來源代碼看一下我們可以發現Gavin King對Hibernate進行了簡單的封裝將EJB EntityBean API調用轉換為內部Hibernate自己的API從而實現EJB EntityBean的兼容

    EJB 不承諾脫離容器調用如果你想享用EJB則必須運行在某個EJB Vendor提供的容器內例如你使用JBoss提供的容器那麼你調用的是EntityBean API這些調用請求會被轉換為Hibernate API的調用請求這意味著Hibernate實際上提供了兩套API一套是Hibernate原生API另一套是兼容EJB EntityBean API對於那些需要分布式調用支持需要EJB容器的開發人員來說他們選擇後一套API對於不需要EJB容器的開發人員來說他們選擇前一套 API這就是Hibernate既定的發展策略

    今年夏天投票通過的JDO標准從某種程度而言並不遜色於 Hibernate當前的版本有些功能甚至比Hibernate還要好例如 JDO支持對類屬性的lazy loading而Hibernate要到才支持當前Hibernate僅僅支持類的lazy loading實際上在去年就已經有很多用戶不斷提出對類屬性的lazy loading的需求然而Gavin King當時一直不認為這個需求有添加的必要性再例如被Gavin King形容為可憎的JDOQL實際上是類SQL查詢語言和對象條件查詢的混合體從功能上來說不如HQL強大但是比Hibernate自己的條件查詢強

    不知道究竟出於什麼原因Gavin King對JDO似乎一直懷有由衷的厭惡他在Hibernate的blog上面對JDO進行了毫不留情的批判列舉了JDO的種種缺點來解釋為什麼EJB持久層規范沒有把JDO考慮進去然而事實上他的批判充滿了對JDO的誤解和偏見例如Gavin King憎恨JDOQL絲毫沒有什麼特別的理由只因為JDOQL不是一個純粹的查詢語言而是一個混合體這多少讓人對Gavin King的風度感到遺憾在被SolarMetric的Abe White反駁之後同樣沒有風度的說我可沒有時間做這種無謂的爭論事實上每個人都認為他自己的技術是最好的……我是錯了JDO那伙人也錯了每個人都會犯錯誤……(所以說人無完人!)

    JDO規范的出台事實上構成了對Hibernate乃至基於 Hibernate理念的EJB EntityBean的嚴重威脅JDO規范在功能上的嚴重缺失導致了JDO無力面對Hibernate和TopLink的競爭然而功能基本完備的JDO挾眾多JDO Vendor商業支持的合力同時JDO規范可以避免產品鎖定在某個Vendor的優勢已經將競爭的天平拉直

[]  []  


From:http://tw.wingwit.com/Article/program/Java/ky/201311/29133.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.