項目中關于持久層的選擇,我主要有兩種選擇:hibernate與ibatis,各有個的好,現在總結如下:
Hibernate簡介
Hibernate是一個開放源代碼的對象關系映射框架,它對JDBC進行了非常輕量級的對象封裝,使得Java程序員可以隨心所欲的使用對象編程思維來操縱數據庫。Hibernate可以應用在任何使用JDBC的場合,既可以在Java的客戶端程序使用,也可以在Servlet/JSP的Web應用中使用,最具革命意義的是,Hibernate可以在應用EJB的J2EE架構中取代CMP,完成數據持久化的重任。
一、基本功能
Hibernate作為數據持久化的中間件,足以讓數據庫在業務邏輯層開發中去冬眠。它通過可擴展標記語言(XML)實現了類和數據表之間的映射,使程序員在業務邏輯的開發中面向數據庫而改為面向對象開發。使整個項目開發分工更加明確,提高了程序開發的效率。
configuration對象:
Configuration?類負責管理Hibernate?的配置信息。Hibernate?運行時需要
獲取一些底層實現的基本信息,其中幾個關鍵屬性包括:
1.?數據庫URL
2.?數據庫用戶
3.?數據庫用戶密碼
4.?數據庫JDBC驅動類
5.數據庫dialect,用于對特定數據庫提供支持,其中包含了針對特定數據庫特性的實現,如Hibernate數據類型到特定數據庫數據類型的映射等。
以上信息一般情況下由hibernate.cfg.xml或者hibernate.properties文件來配置,實現與不同數據庫的連接。
Session對象:
Session是持久層操作的基礎,相當于JDBC中的Connection:
實例通過SessionFactory實例構建:
Configuration?config?=?new?Configuration().configure();
SessionFactory?sessionFactory?=?config.buildSessionFactory();
Session?session?=?sessionFactory.openSession();
之后我們就可以調用Session所提供的save、find、flush等方法完成持久層操作。因此Session對象也封裝了所有對數據庫的操作來實現Hibernate對數據庫的操縱功能,如:
Save()方法實現增加和保存;
Delete()方法實現數據的刪除;
Update()方法實現數據更新和修改;
Find()方法實現數據的檢索;
Hibernate會根據不同的操作自動生成相應的SQL語句,從而實現了程序員對PO對象的操作轉化為對數據庫關系表的操作。
二、使用步驟
1.編寫Hibernate配置文件
???????Hibernate配置文件有兩種,分別是hibernate.cfg.xml文件和hibernate.properties,推薦使用hibernate.cfg.xml。
2.PO和映射文件
使用middlegen和hibernate-extensions從數據庫導出PO的映射文件,并在hibernate.cfg.xml當中聲明。
3.編寫DAO
???????對每一張關系表編寫一個DAO,提供一組增、刪、改、查方法供業務邏輯對數據庫操作使用。
Ibatis簡介
相對Hibernate和Apache?OJB?等"一站式"ORM解決方案而言,ibatis?是一種"半自動化"的ORM實現。所謂"半自動",可能理解上有點生澀。縱觀目前主流的ORM,無論Hibernate?還是Apache?OJB,都對數據庫結構提供了較為完整的封裝,提供了從POJO?到數據庫表的全套映射機制。程序員往往只需定義好了POJO?到數據庫表的映射關系,即可通過Hibernate或者OJB?提供的方法完成持久層操作。程序員甚至不需要對SQL?的熟練掌握,Hibernate/OJB?會根據制定的存儲邏輯,自動生成對應的SQL?并調用JDBC?接口加以執行。
Ibatis最直接的好處就是不但為程序員提供了對象與關系數據庫之間的映射,同時提供操作方法與SQL間的直接影射,設計者可以直接為一個方法指定一條SQL語句,從而取得更加準確的數據,同時為優化查詢、連接查詢提供了方便。
一、基本功能
作為又一個輕量級的ORM中間件,ibatis除了提供了對數據庫基本的增、刪、改、查外還提供了連接管理,緩存支持,線程支持,(分布式)事物管理等一套教為完整的數據庫管理功能。
SqlMapClient對象是ibatis持久層操作的基礎,相當于hibernate中的session,提供對SQL映射的方法。
insert()方法實現對插入SQL語句的映射;
delete()方法實現對刪除SQL語句的映射;
update()方法實現對更新SQL語句的影射;
queryForList()、queryForMap()、queryForObject()、queryForPaginatedList()等方法提供了一組查詢SQL語句的影射;
二、使用步驟
1.ibatis?SQL?Map?配置文件
???????文件中對所用數據庫的連接做了基本配置,包括數據庫驅動類型、用戶名、密碼,以及連接池的相關管理數據。
2.PO和映射文件
???????和hibernate一樣,PO作為數據庫關系表的影射,也需要響應的映射配置文件,可以手寫,也可以借助hibernate的相關工具生成PO,不會影響PO在ibatis中的使用。與hibernate不同的是,ibatis的映射文件中沒有對PO中每個屬性做響應的描述,而是指定了一系列與PO有關的SQL相關操作,也體現了ibatis良好的靈活性與可擴展性。
3.編寫DAO
???????在DAO中,可以使用SqlMapClient提供的方法來對應的指定對PO操作的SQL語句,從而使業務邏輯層的開發仍然是面向對象的操作。
選擇Hibernate還是iBATIS都有它的道理:
Hibernate的特點:
Hibernate功能強大,數據庫無關性好,O/R映射能力強,如果你對Hibernate相當精通,而且對Hibernate進行了適當的封裝,那么你的項目整個持久層代碼會相當簡單,需要寫的代碼很少,開發速度很快,非常爽。以數據庫字段一一對應映射得到的PO和Hibernte這種對象化映射得到的PO是截然不同的,本質區別在于這種PO是扁平化的,不像Hibernate映射的PO是可以表達立體的對象繼承,聚合等等關系的,這將會直接影響到你的整個軟件系統的設計思路。Hibernate對數據庫結構提供了較為完整的封裝,Hibernate的O/R?Mapping實現了POJO?和數據庫表之間的映射,以及SQL?的自動生成和執行。程序員往往只需定義好了POJO?到數據庫表的映射關系,即可通過Hibernate?提供的方法完成持久層操作。程序員甚至不需要對SQL?的熟練掌握,?Hibernate/OJB?會根據制定的存儲邏輯,自動生成對應的SQL?并調用JDBC?接口加以執行。Hibernate的缺點就是學習門檻不低,要精通門檻更高,而且怎么設計O/R映射,在性能和對象模型之間如何權衡取得平衡,以及怎樣用好Hibernate方面需要你的經驗和能力都很強才行,但是Hibernate現在已經是主流O/R?Mapping框架,從文檔的豐富性,產品的完善性,版本的開發速度都要強于iBATIS。
iBATIS的特點:
iBATIS入門簡單,即學即用,提供了數據庫查詢的自動對象綁定功能,而且延續了很好的SQL使用經驗,對于沒有那么高的對象模型要求的項目來說,相當完美。iBATIS的缺點就是框架還是比較簡陋,功能尚有缺失,雖然簡化了數據綁定代碼,但是整個底層數據庫查詢實際還是要自己寫的,工作量也比較大,而且不太容易適應快速數據庫修改。當系統屬于二次開發,無法對數據庫結構做到控制和修改,那iBATIS的靈活性將比Hibernate更適合。系統數據處理量巨大,性能要求極為苛刻,這往往意味著我們必須通過經過高度優化的SQL語句(或存儲過程)才能達到系統性能設計指標。在這種情況下iBATIS會有更好的可控性和表現。
對于實際的開發進行的比較:
1.?iBATIS需要手寫sql語句,也可以生成一部分,Hibernate則基本上可以自動生成,偶爾會寫一些Hql。同樣的需求,iBATIS的工作量比?Hibernate要大很多。類似的,如果涉及到數據庫字段的修改,Hibernate修改的地方很少,而iBATIS要把那些sql?mapping的地方一一修改。
2.?iBatis?可以進行細粒度的優化
比如說我有一個表,這個表有幾個或者幾十個字段,我需要更新其中的一個字段,iBatis?很簡單,執行一個sql?UPDATE?TABLE_A?SET?column_1=#column_1#?WHERE?id=#id#?但是用?Hibernate?的話就比較麻煩了,缺省的情況下?hibernate?會更新所有字段。?當然我記得?hibernate?有一個選項可以控制只保存修改過的字段,但是我不太確定這個功能的負面效果。
例如:我需要列出一個表的部分內容,用?iBatis?的時候,這里面的好處是可以少從數據庫讀很多數據,節省流量SELECT?ID,?NAME?FROM?TABLE_WITH_A_LOT_OF_COLUMN?WHERE?...一般情況下Hibernate?會把所有的字段都選出來。比如說有一個上面表有8個字段,其中有一兩個比較大的字段,varchar(255)/text。上面的場景中我為什么要把他們也選出來呢?用hibernate?的話,你又不能把這兩個不需要的字段設置為lazy?load,因為還有很多地方需要一次把整個?domain?object?加載出來。這個時候就能顯現出ibatis?的好處了。如果我需要更新一條記錄(一個對象),如果使用?hibernate,需要現把對象?select?出來,然后再做?update。這對數據庫來說就是兩條sql。而iBatis只需要一條update的sql就可以了。減少一次與數據庫的交互,對于性能的提升是非常重要。
3.?開發方面:
開發效率上,我覺得兩者應該差不多。可維護性方面,我覺得?iBatis?更好一些。因為?iBatis?的?sql?都保存到單獨的文件中。而?Hibernate?在有些情況下可能會在?java?代碼中保sql/hql。相對Hibernate“O/R”而言,iBATIS?是一種“Sql?Mapping”的ORM實現。而iBATIS?的著力點,則在于POJO?與SQL之間的映射關系。也就是說,iBATIS并不會為程序員在運行期自動生成SQL?執行。具體的SQL?需要程序員編寫,然后通過映射配置文件,將SQL所需的參數,以及返回的結果字段映射到指定POJO。使用iBATIS?提供的ORM機制,對業務邏輯實現人員而言,面對的是純粹的Java對象,這一層與通過Hibernate?實現ORM?而言基本一致,而對于具體的數據操作,Hibernate會自動生成SQL?語句,而iBATIS?則要求開發者編寫具體的SQL?語句。相對Hibernate而言,iBATIS?以SQL開發的工作量和數據庫移植性上的讓步,為系統設計提供了更大的自由空間。
4.?運行效率
在不考慮?cache?的情況下,iBatis?應該會比hibernate?快一些或者很多。