溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

iBATIS與Hibernate間有什么區別

發布時間:2021-11-30 15:39:24 來源:億速云 閱讀:484 作者:小新 欄目:編程語言

小編給大家分享一下iBATIS與Hibernate間有什么區別,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

iBATIS與Hibernate間的取舍都是程序員要選擇的一個問題,我在最初的選型的時候是打算選擇Hibernate 的,在研究的過程中發現了iBATIS,經過分析比較之后我選擇了iBATIS?,F在我已經使用iBATIS 完成了一個中小型的項目。這個項目在性能、可維護性、可擴展性方面都非常令我滿意。

在這個過程中我也不斷的與使用過或者正在使用 Hibernate 的人進行過探討。而且我本身也在不斷的跟進 Hibernate 的發展。最終,我的結論是iBATIS 的選擇非常正確,而且越用越喜歡它了。當然了,我對 Hibernate 的理解還是非常有限的,所以這里的關于 Hibernate 的一些觀點的錯誤之處希望能夠得到 Hibernate 高手的指正。

1.iBATIS易于掌握。

拿來文檔看半天到兩天就可以掌握了。Hibernate 可能需要 3 倍以上的時間來掌握。

2. iBATIS更容易進行 sql 的 優化。

這個應該大家都有共識了。另外 Hibernate 生成的 sql 也實在是太難看了。鑒于有的朋友提到了 sql 不太重要。我想在這里強調一下我的經驗,一般系統性能的瓶頸都在數據庫上。所以這一點是iBATIS非常重要的一個優勢。

3.iBATIS可以進行細粒度的優化

3.1 比如說我有一個表,這個表有幾個或者幾十個字段,我需要更新其中的一個字段,iBATIS很簡單,執行一個sql UPDATE TABLE_A SET column_1=#column_1# WHERE id=#id# 但是用 Hibernate 的話就比較麻煩了,缺省的情況下Hibernate會更新所有字段。當然我記得Hibernate有一個選項可以控制只保存修改過的字段,但是我不太確定這個功能的負面效果。

3.2 我需要列出一個表的部分內容,用iBATIS 的時候,這里面的好處是可以少從數據庫讀很多數據,節省流量SELECT ID, NAME FROM TABLE_WITH_A_LOT_OF_COLUMN WHERE ...

3.2.1 一般情況

Hibernate 會把所有的字段都選出來。比如說有一個上面表有8個字段,其中有一兩個比較大的字段,varchar(255)/text。上面的場景中我為什么要把他們也選出來呢?

3.2.2 用Hibernate的話,你又不能把這兩個不需要的字段設置為 lazy load,因為還有很多地方需要一次把整個 domain object 加載出來。這個時候就能顯現出iBATIS的好處了

3.2.3 Hibernate 還有一個方案,就是生成 javabean/map/object[](感謝leelun/cjmm),但是這樣的話就可能會產生大量的多余 class。map/object[] 的方式應該不錯,我比較喜歡這種方式。

3.3 如果我需要更新一條記錄(一個對象),如果使用Hibernate,需要現把對象 select 出來,然后再做 update。這對數據庫來說就是兩條 sql。而iBATIS只需要一條 update 的 sql 就可以了。減少一次與數據庫的交互,對于性能的提升是非常重要。

4. 開發方面

4.1 開發效率上,我覺得兩者應該差不多

4.2 可維護性方面,我覺得iBATIS更好一些。因為iBATIS的sql都保存到單獨的文件中。而 Hibernate 在有些情況下可能會在 java 代碼中保存
sql/hql。

5. 運行效率

5.1 在不考慮 cache 的情況下,iBATIS應該會比Hibernate快一些或者很多(根據實際情況會有所不同)。

當然iBATIS也有比較大的缺點

1. 不同數據庫類型的支持不好,如果你要開發的系統是要在對中數據間移植,那可能用Hibernate比較好。

2. 缺省的 cache 支持不好,但是Hibernate的 cache 支持其實也不是很好,而且很復雜。尤其是對于大并發量的應用。所以我更傾向于自己管理 cache。

以上是“iBATIS與Hibernate間有什么區別”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女