Mybatis和Hibernate區別
首先簡單介紹下兩者的概念:
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本身提供的快取機制不佳。