Hibernate 與mybatis的區別

爲方便以後準備面試,把一些常用的技術整理出來,會不定期更新。

首先簡單介紹下兩者的概念:

Hibernate :Hibernate 是當前最流行的ORM框架,對數據庫結構提供了較爲完整的封裝。

Mybatis:Mybatis同樣也是非常流行的ORM框架,主要着力點在於POJO 與SQL之間的映射關係。

其次具體從幾個方面說一下兩者的區別:

1.兩者最大的區別:

針對簡單邏輯,Hibernate和MyBatis都有相應的代碼生成工具,可以生成簡單基本的DAO層方法。

針對高級查詢,Mybatis需要手動編寫SQL語句,以及ResultMap。而Hibernate有良好的映射機制,開發者無需關心SQL的生成與結果映射,可以更專注於業務流程。

2.開發難度對比

Hibernate的開發難度要大於Mybatis。主要由於Hibernate比較複雜、龐大,學習週期較長。

而Mybatis則相對簡單一些,並且Mybatis主要依賴於sql的書寫,讓開發者感覺更熟悉。

3.sql書寫比較

Mybatis的SQL是手動編寫的,所以可以按需求指定查詢的字段。不過沒有自己的日誌統計,所以要藉助log4j來記錄日誌。

Hibernate也可以自己寫SQL來指定需要查詢的字段,但這樣就破壞了Hibernate開發的簡潔性。不過Hibernate具有自己的日誌統計。

4.數據庫擴展性比較

Mybatis由於所有SQL都是依賴數據庫書寫的,所以擴展性,遷移性比較差。

Hibernate與數據庫具體的關聯都在XML中,所以HQL對具體是用什麼數據庫並不是很關心。

5.緩存機制比較

相同點:Hibernate和Mybatis的二級緩存除了採用系統默認的緩存機制外,都可以通過實現你自己的緩存或爲其他第三方緩存方案,創建適配器來完全覆蓋緩存行爲。

不同點:Hibernate的二級緩存配置在SessionFactory生成的配置文件中進行詳細配置,然後再在具體的表-對象映射中配置是那種緩存。

MyBatis的二級緩存配置都是在每個具體的表-對象映射中進行詳細配置,這樣針對不同的表可以自定義不同的緩存機制。並且Mybatis可以在命名空間中共享相同的緩存配置和實例,通過Cache-ref來實現。

兩者比較:因爲Hibernate對查詢對象有着良好的管理機制,用戶無需關心SQL。所以在使用二級緩存時如果出現髒數據,系統會報出錯誤並提示。

而MyBatis在這一方面,使用二級緩存時需要特別小心。如果不能完全確定數據更新操作的波及範圍,避免Cache的盲目使用。否則,髒數據的出現會給系統的正常運行帶來很大的隱患。

6.總結:

Hibernate與MyBatis都可以是通過SessionFactoryBuider由XML配置文件生成SessionFactory,然後由SessionFactory 生成Session,最後由Session來開啓執行事務和SQL語句。

而MyBatis的優勢是MyBatis可以進行更爲細緻的SQL優化,可以減少查詢字段,並且容易掌握。

Hibernate的優勢是DAO層開發比MyBatis簡單,Mybatis需要維護SQL和結果映射。數據庫移植性很好,MyBatis的數據庫移植性不好,不同的數據庫需要寫不同SQL。有更好的二級緩存機制,可以使用第三方緩存。MyBatis本身提供的緩存機制不佳。

發佈了3 篇原創文章 · 獲贊 2 · 訪問量 7232
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章