選擇Hibernate還是iBatis?(轉Javaeye)

          選擇Hibernate還是iBATIS都有它的道理:

          Hibernate功能強大,數據庫無關性好,O/R映射能力強,如果你對Hibernate相當精通,而且對Hibernate進行了適當的封裝,那么你的項目整個持久層代碼會相當簡單,需要寫的代碼很少,開發速度很快,非常爽。

          Hibernate的缺點就是學習門檻不低,要精通門檻更高,而且怎么設計O/R映射,在性能和對象模型之間如何權衡取得平衡,以及怎樣用好Hibernate方面需要你的經驗和能力都很強才行。

          iBATIS入門簡單,即學即用,提供了數據庫查詢的自動對象綁定功能,而且延續了很好的SQL使用經驗,對于沒有那么高的對象模型要求的項目來說,相當完美。

          iBATIS的缺點就是框架還是比較簡陋,功能尚有缺失,雖然簡化了數據綁定代碼,但是整個底層數據庫查詢實際還是要自己寫的,工作量也比較大,而且不太容易適應快速數據庫修改。

          我的建議就是:

          如果你的團隊沒有Hibernate高手,那么請用iBATIS,要把Hibernate用好,并不容易;否則你應該選擇Hibernate,那樣你的開發速度和代碼簡潔性都相當棒!

          BTW:

          我覺得rails的ActiveRecord是平衡性做的最好的,避免了Hibernate的復雜性和學習HQL的成本,同時具備iBATIS即學即用的簡單性。

          ------------------------------------------------------------------------------------------------------------------------

          簡介

          Hibernate 是當前最流行的O/R mapping框架,當前版本是3.05。它出身于sf.net,現在已經成為Jboss的一部分了

           

          iBATIS 是另外一種優秀的O/R mapping框架,當前版本是2.0。目前屬于apache的一個子項目了。

          相對HibernateO/R”而言,iBATIS 是一種“Sql Mapping”的ORM實現。

           

          Hibernate對數據庫結構提供了較為完整的封裝,HibernateO/R Mapping實現了POJO 和數據庫表之間的映射,以及SQL 的自動生成和執行。程序員往往只需定義好了POJO 到數據庫表的映射關系,即可通過Hibernate 提供的方法完成持久層操作。程序員甚至不需要對SQL 的熟練掌握, Hibernate/OJB 會根據制定的存儲邏輯,自動生成對應的SQL 并調用JDBC 接口加以執行。

           

          iBATIS 的著力點,則在于POJO SQL之間的映射關系。也就是說,iBATIS并不會為程序員在運行期自動生成SQL 執行。具體的SQL 需要程序員編寫,然后通過映射配置文件,將SQL所需的參數,以及返回的結果字段映射到指定POJO

          使用iBATIS 提供的ORM機制,對業務邏輯實現人員而言,面對的是純粹的Java對象,

          這一層與通過Hibernate 實現ORM 而言基本一致,而對于具體的數據操作,Hibernate會自動生成SQL 語句,而iBATIS 則要求開發者編寫具體的SQL 語句。相對Hibernate而言,iBATIS SQL開發的工作量和數據庫移植性上的讓步,為系統設計提供了更大的自由空間。

          二者的對比:

          1.  iBATIS非常簡單易學,Hibernate相對較復雜,門檻較高。

          2.  二者都是比較優秀的開源產品

          3.  當系統屬于二次開發,無法對數據庫結構做到控制和修改,iBATIS的靈活性將比Hibernate更適合

          4.  系統數據處理量巨大,性能要求極為苛刻,這往往意味著我們必須通過經過高度優化的SQL語句(或存儲過程)才能達到系統性能設計指標。在這種情況下iBATIS會有更好的可控性和表現。

          5.  iBATIS需要手寫sql語句,也可以生成一部分,Hibernate則基本上可以自動生成,偶爾會寫一些Hql。同樣的需求,iBATIS的工作量比Hibernate要大很多。類似的,如果涉及到數據庫字段的修改,Hibernate修改的地方很少,而iBATIS要把那些sql mapping的地方一一修改。

          6.  以數據庫字段一一對應映射得到的POHibernte這種對象化映射得到的PO是截然不同的,本質區別在于這種PO是扁平化的,不像Hibernate映射的PO是可以表達立體的對象繼承,聚合等等關系的,這將會直接影響到你的整個軟件系統的設計思路。

          7.  Hibernate現在已經是主流O/R Mapping框架,從文檔的豐富性,產品的完善性,版本的開發速度都要強于iBATIS

          8.  最關鍵的一句話是iBATIS的作者說的:

          If you are starting a new project and you're in full control of your object model and database design, Hibernate is a good choice of O/R tool.

          If you are accessing any 3rd party databases (e.g. vendor supplied), or you're working with a legacy database, or even just a really poorly designed database, then an O/R mapper might not be capable of handling the situation. That's were an SQL Mapper comes in handy

           

          結論:

          結論:

          Hibernate 和iBATIS可以說是互相補充,共同發展的關系.具體你想用什么要看實際情況.如果看了上面的文字還是拿不定注意,那就Just to try it.實踐是檢驗真理的唯一標準.鞋合不合適,只有試了才知道

          posted on 2008-05-22 13:40 bc 閱讀(141) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發表評論。


          網站導航:
          博客園   IT新聞   Chat2DB   C++博客   博問  
           
          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          導航

          統計

          常用鏈接

          留言簿

          隨筆檔案

          文章檔案

          搜索

          最新評論

          主站蜘蛛池模板: 大理市| 拉萨市| 札达县| 鄂尔多斯市| 兰考县| 琼结县| 和龙市| 五常市| 忻城县| 肇源县| 太和县| 巴东县| 关岭| 阿拉善右旗| 铁岭市| 临颍县| 永州市| 屯昌县| 嵩明县| 汨罗市| 江陵县| 绩溪县| 长白| 宁南县| 武宁县| 乐都县| 无棣县| 西城区| 淅川县| 司法| 峡江县| 织金县| 安国市| 蒙阴县| 乐东| 林甸县| 闽清县| 禹城市| 万宁市| 亚东县| 城固县|