自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Hibernate與IBatis的優(yōu)缺點及可行性分析

開發(fā) 后端
本文對Hibernate與IBatis從功能完整性、滯后性等多個方面進行分析比較,作者希望大家可以在項目中借鑒IBatis的思路。

1.優(yōu)點

簡單:

易于學習,易于使用,通過文檔和源代碼,可以比較完全的掌握它的設計思路和實現(xiàn)。

實用:

提供了數(shù)據(jù)映射功能,提供了對底層數(shù)據(jù)訪問的封裝(例如ado.net),提供了dao框架,可以使我們更容易的開發(fā)和配置我們的dal層。

靈活:

通過sql基本上可以實現(xiàn)我們不使用數(shù)據(jù)訪問框架可以實現(xiàn)的所有功能,或許更多。

功能完整:

提供了連接管理,緩存支持,線程支持,(分布式)事物管理,通過配置作關系對象映射等數(shù)據(jù)訪問層需要解決的問題。提供了dao支持,并在dao框架中封裝了ado.net,Hibernate和datamapper。

增強系統(tǒng)的可維護性:
通過提供dal層,將業(yè)務邏輯和數(shù)據(jù)訪問邏輯分離,使系統(tǒng)的設計更清晰,更易維護,更易單元測試。sql和代碼的分離,提高了可維護性。

2.缺點

滯后性:

還沒有明確對.net2.0的支持。最新版本在2.0下編譯可以,但有些單元測試不能通過。
不成熟,工程實踐較少:
ibatisnet在實際項目中的使用較少。 只是理論上可行.
半orm,工具支持較少:
需要我們自己寫sql,并且.net下還未發(fā)現(xiàn)可以自動生成業(yè)務層類和配置文件的工具,這點和Hibernate不一樣,Hibernate會為我們的數(shù)據(jù)庫直接產(chǎn)生sql,并有一些輔助工具。因此使用ibatis比Hibernate要多做一些工作。

3.可行性

沒有最好的框架,只有最適合的框架。 存在的便是合理的,它存在就說明有它存在的道理。但它未必為我們存在。所以選擇一個框架最主要的是看它對你有沒有意義,意義有多大,是不是比其他框架帶給 你的好處要多。沒有絕對的優(yōu)點也沒有絕對的缺點,重要的是看在什么情況下討論。
上面說了部分的ibatis的優(yōu)點和部分缺點。這些優(yōu)點從理論上證明ibatis對任何數(shù)據(jù)持久層都合適,但未必是最好的選擇。下面對上面的優(yōu)缺點分別從兩方面討論。

簡單:

我們都喜歡簡單,簡單意味著學習成本低,使用中出錯的可能性低。同時,簡單的東西一般來說功能不夠強大。反過來,復雜的東西學習成本高,用起來不方便,并且團隊沒有很強的技術實力,一般不要使用。

實用:

解決了項目中需要解決的問題,這是任何實際工程中采用的框架和工具都應具有的性質(zhì),否則就不要拿到實際項目中來。

靈活:

靈活有兩層意思,一種是簡單易擴展,另一種是功能強大提供了很多選項。ibatis屬于前者,Hibernate屬于后者。兩者各有優(yōu)缺點。

功能完整:

ibatis的功能完整也是相對的,比我們自己開發(fā)的框架應該完整,但對比其他框架肯定也有一些解決不了的問題。
增強系統(tǒng)的可維護性:
利用ibatis可以做到sql和代碼分離,可以設計出一個清晰的數(shù)據(jù)訪問層(dal)。但項目架構是否科學合理,是否以維護,關鍵不在ibatis,因 為它只是一個數(shù)據(jù)層框架。但是我們也不得不清楚,要想發(fā)揮ibatis的優(yōu)勢,我們需要做一些額外工作,比如最好設計dao接口,需要將業(yè)務層實體和對實 體的訪問放在不同的工程中,同時需要維護xml配置文件。

滯后性:

ibatis組現(xiàn)在還沒有提到要支持.net2.0,很多人在.net2.0下使用ibatis都出現(xiàn)了問題。所以如果要使用.net2.0開發(fā),ibatis不是一個好選擇,還需要等待。

不成熟:

開源的東西很難說成熟,但一般比我們自己寫的框架要成熟。由于我們可以拿到他的源代碼,所以關鍵在于我們能否駕馭它。

半orm,工具支持少:

這注定了ibatis不能從本質(zhì)上提升開發(fā)效率,我們需要自己寫sql,寫實體類,寫配置文件。但這也是它優(yōu)越的地方,它沒有為我們做的他多,所以我們就 有更多的施展空間。而且它非常適合那些并不能完全控制數(shù)據(jù)庫的系統(tǒng)和需要利用數(shù)據(jù)庫本身提供的高級特性的統(tǒng)計查詢系統(tǒng)的開發(fā)。
使用ibatis需要自己寫sql,由于我們的sql不可能完全符合sql標準,比起Hibernate產(chǎn)生的sql來,可移植性差。不過由于我們更改 數(shù)據(jù)庫的可能性較小,對我們來說sql符合標準以便可以在遷移到不同服務器時代價最小并不是十分必要的。另一方面,Hibernate雖然可以屏蔽很多 數(shù)據(jù)庫間的不同,但是卻很難利用某些數(shù)據(jù)庫的高級特性,比如oracle的分析統(tǒng)計函數(shù)。
Hibernate不適合數(shù)據(jù)庫模式不規(guī)范,約束不完整,需要大量復雜查詢的系統(tǒng),同時Hibernate的學習成本較高,完全掌握Hibernate也較困難,風險較大。
自己寫框架未必比ibatis的好,穩(wěn)定,強大和可擴展。而且自己開發(fā)框架也需要較大的工作量。
如果使用dotnet并且要選一個數(shù)據(jù)層框架,而系統(tǒng)中有相當一部分較復雜的sql,或數(shù)據(jù)庫設計不合理,臟數(shù)據(jù)多,對性能和資源要求嚴格,ibatis 是一個比較不錯的選擇。他的那些缺點并不是致命的,而且也是有一些解決方案的。尤其是,當選用了ibatis的dataaccess作為dao框架時,我 們可以同時使用Hibernate,ado.net和datamapper(ibatisnet的核心組件),那樣將會使風險降到最低,并且整個系統(tǒng)的 框架比較合理。
另外,利用ibatis可以統(tǒng)一編碼風格,節(jié)約開發(fā)成本,大家不會再把精力浪費到分頁 連接池 主鍵生成等地方了,可以集中精力進行業(yè)務組件的編寫。

綜上: 很多時候我們要在是自己開發(fā)框架和選用第三方框架和選用什么樣的框架問題上進行綜合考慮??紤]的標準當然是項目的當前情況和我們希望達到目的的一個平衡。

ibatis只是封裝了數(shù)據(jù)訪問層,替我們做了部分的對象關系映射。但我們的代價是必須要寫xml配置文件,相對于Hibernate我們還要寫很多 sql。Hibernate通過工具直接從數(shù)據(jù)庫模式生成實體類和基本的配置文件,而且大部分情況下不需要我們寫sql,會較大的提升開發(fā)效率。但這些也 有很多的局限性,尤其是對環(huán)境的要求較高(數(shù)據(jù)庫設計,對象設計,團隊的協(xié)作等)。

個人感覺ibatis對項目比較有意義的地方在于它小巧靈活,可擴展,封裝了數(shù)據(jù)訪問層(事務,緩存,異常,日志),并提供了dao框架支持。

利用ibatis我們可以做到代碼和sql的分離,只要sql能夠解決的問題,ibatis就能幫我們較容易的解決,同時也使我們的項目對某一框架的依賴 性變?。ㄒ驗閕batis是非侵入性的)。這將極大的降低項目風險,減少解決復雜問題的時間,使項目的維護變得簡單。

ibatis對于應用的修改,調(diào)試,擴充和維護將會變得容易自然。修改時,我們主要修改的是代表模型的實體對象,xml配置文件中的sql,和/或配置文 件的resultmap(很多時候是不需要的)。同時,sql和代碼分離,我們不用在代碼的stringbuffer的append方法之間尋找需要修改 的sql。配置文件中的sql便利了我們的調(diào)試和對sql的評審及以后的sql重用。

利用一些框架在前期一般會拖慢開發(fā)效率。因為我們需要付出學習成本,很多時候,使用框架需要寫很多配置文件,在使用不熟時開發(fā)速度較慢;同時利用框架往往 使系統(tǒng)代碼量增大,比如model1和model2模型,開發(fā)效率應該還是model1快,四層的架構肯定比兩層的代碼量大。 但對于中后期開發(fā)和維護將會極大的提高效率。

利用一些較完全的開發(fā)框架和代碼生成工具,在前期會較大的提高開發(fā)效率,但在后期常常會拖慢進度,并有可能成為以后維護的夢魘。比如torque生成實體類和其對應的sql,雖大幅提高了效率,但修改負擔較大。

比較理想的開發(fā)方式是使用簡單框架結合簡單的代碼生成工具??蚣芴峁┫到y(tǒng)的基礎服務,并規(guī)范開發(fā)。框架一方面提供了開發(fā)中某一方面的開發(fā)基礎支持,比如數(shù) 據(jù)訪問層,事務,日志,公用類,異常等。另一方面,也為開發(fā)定義了模式,定義了系統(tǒng)的基本輪廓。同時,通過簡單的代碼生成工具生成部分低級的代碼。比如通 過工具從數(shù)據(jù)庫模式生成實體類。這些類生成后我們可以自由修改。

Hibernate是十分強大,比較完善的orm框架,不過這是它的優(yōu)點也是它的缺點。 J2EE系統(tǒng)是否采用Hibernate3,是一個需要認真評估的問題。

要想Hibernate工作的好,數(shù)據(jù)庫的設計必須好。同時對于復雜的數(shù)據(jù)操作同時需要使用sql,Hibernate3對于直接使用sql的支持比Hibernate2要自然,這一點是可以接受的。

Hibernate比較復雜,功能強大而靈活,要用好Hibernate確實不是很簡單,當然spring框架提供了對Hibernate的封裝,使Hibernate的使用變得簡單了點。

可以說ibatis在任何系統(tǒng)里都適用,但未必是最好選擇。不過ibatis提供的思路是我們應該仔細考慮的。

【編輯推薦】

  1. Hibernate中l(wèi)oad和get的兩大區(qū)別
  2. Hibernate HQL sum查詢對象獲取的感受
  3. 對Hibernate sum函數(shù)的使用之分析
  4. 初學者適用的Hibernate學習方法
  5. Hibernate API進行批量更新存在的缺點
責任編輯:張攀 來源: 博客園
相關推薦

2009-09-21 16:40:42

Hibernate可行

2012-04-12 17:41:02

2009-06-19 18:36:15

JPAHibernate

2012-04-09 09:39:59

虛擬化桌面虛擬化VDI終端

2009-12-25 14:26:40

無線接入技術集成

2011-04-28 11:04:22

DataReader分頁

2013-08-27 11:15:20

2011-12-13 20:36:26

Android

2009-06-12 10:09:17

2009-09-24 14:04:25

Hibernate i

2022-03-11 08:31:50

API網(wǎng)關微服務

2011-08-17 13:07:19

無線局域網(wǎng)

2011-06-24 11:35:01

內(nèi)鏈

2009-07-17 13:13:47

iBATIS Hibe

2009-09-22 13:12:25

Hibernateibatis

2011-07-05 14:12:06

關鍵任務虛擬化服務器

2011-07-05 10:37:03

虛擬化VMware

2009-02-17 15:59:55

2010-06-21 14:14:33

OSPF協(xié)議

2009-07-17 10:08:39

Hibernate與i
點贊
收藏

51CTO技術棧公眾號