1. 簡介
Hibernate是當前最流行的O/R mapping框架。它出身于sf.net,現在已經成為Jboss的一部分了。iBATIS是另外一種優秀的O/R mapping框架,現已改名叫myBATIS。目前屬于apache的一個子項目了。相對Hibernate"O/R"而言,iBATIS 是一種"Sql Mapping"的ORM實現。
Hibernate對數據庫結構提供了較為完整的封裝,Hibernate的O/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開發的工作量和數據庫移植性上的讓步,為系統設計提供了更大的自由空間。
2. 二者的對比
1)iBATIS非常簡單易學,Hibernate相對較復雜,門檻較高。iBATIS拿來文檔看半天到兩天就可以掌握了。Hibernate可能需要3倍以上的時間來掌握。
2) 二者都是比較優秀的開源產品。但Hibernate現在已經是主流O/R Mapping框架,從文檔的豐富性,產品的完善性,版本的開發速度都要強于iBATIS。
3) 當系統屬于二次開發,無法對數據庫結構做到控制和修改,那iBATIS的靈活性將比Hibernate更適合。
4) 系統數據處理量巨大,性能要求極為苛刻,這往往意味著我們必須通過經過高度優化的SQL語句(或存儲過程)才能達到系統性能設計指標。在這種情況下iBATIS會有更好的可控性和表現。iBatis比Hibernate更容易進行sql的優化。鑒于一般系統性能的瓶頸都在數據庫上,所以這一點是iBatis非常重要的一個優勢。
5) iBatis 可以進行細粒度的優化
6) iBatis需要手寫sql語句,也可以生成一部分,Hibernate則基本上可以自動生成,偶爾會寫一些Hql。同樣的需求,iBATIS的工作量比Hibernate要大很多。類似的,如果涉及到數據庫字段的修改,Hibernate修改的地方很少,而iBATIS要把那些sql mapping的地方一一修改。
7) 開發方面
8) 運行效率在不考慮cache的情況下,iBatis應該會比hibernate快一些或者很多(根據實際情況會有所不同)。9) 對不同數據庫類型的支持。iBatis對不同數據庫類型的支持不夠好,如果你要開發的系統是要在對中數據間移植,那可能用hibernate比較好。
10)對缺省的cache支持。iBatis對缺省的cache支持不夠好,但是hibernate的cache支持其實也不是很好,而且很復雜。尤其是對于大并發量的應用。所以我更傾向于自己管理cache。
11) 以數據庫字段一一對應映射得到的PO(persistantobject)和Hibernte這種對象化映射得到的PO是截然不同的,本質區別在于這種PO是扁平化的,不像Hibernate映射的PO是可以表達立體的對象繼承,聚合等等關系的,這將會直接影響到你的整個軟件系統的設計思路。
12) 最關鍵的一句話是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
3. 如何選擇
選擇Hibernate還是iBATIS都有它的道理:
原文出處:http://blog.csdn.net/ya2dan/article/details/7396598
新聞熱點
疑難解答