1. 程式人生 > 實用技巧 >MyBatis 與 Hibernate 有哪些不同?

MyBatis 與 Hibernate 有哪些不同?

MyBatis與Hibernate區別

背景:在中國網安的面試過程中遇到這個問題,好長時間沒用了,說不出個所以然來。
MyBatis與Hibernate區別

7、Hibernate與MyBatis對比

7.1 相同點

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

其中SessionFactoryBuider,SessionFactory,Session的生命週期都是差不多的。Hibernate和MyBatis都支援JDBC和JTA事務處理。

7.2 不同點

(1)hibernate是全自動,而mybatis是半自動

hibernate完全可以通過物件關係模型實現對資料庫的操作,擁有完整的JavaBean物件與資料庫的對映結構來自動生成sql。而mybatis僅有基本的欄位對映,物件資料以及物件實際關係仍然需要通過手寫sql來實現和管理。

(2)hibernate資料庫移植性遠大於mybatis

hibernate通過它強大的對映結構和hql語言,大大降低了物件與資料庫(Oracle、MySQL等)的耦合性,而mybatis由於需要手寫sql,因此與資料庫的耦合性直接取決於程式設計師寫sql的方法,如果sql不具通用性而用了很多某資料庫特性的sql語句的話,移植性也會隨之降低很多,成本很高。

(3)hibernate擁有完整的日誌系統,mybatis則欠缺一些

hibernate日誌系統非常健全,涉及廣泛,包括:sql記錄、關係異常、優化警告、快取提示、髒資料警告等;而mybatis則除了基本記錄功能外,功能薄弱很多。

(4)mybatis相比hibernate需要關心很多細節

hibernate配置要比mybatis複雜的多,學習成本也比mybatis高。但也正因為mybatis使用簡單,才導致它要比hibernate關心很多技術細節。mybatis由於不用考慮很多細節,開發模式上與傳統jdbc區別很小,因此很容易上手並開發專案,但忽略細節會導致專案前期bug較多,因而開發出相對穩定的軟體很慢,而開發出軟體卻很快。hibernate則正好與之相反。但是如果使用hibernate很熟練的話,實際上開發效率絲毫不差於甚至超越mybatis。

(5)sql直接優化上,mybatis要比hibernate方便很多

由於mybatis的sql都是寫在xml裡,因此優化sql比hibernate方便很多。而hibernate的sql很多都是自動生成的,無法直接維護sql;雖有hql,但功能還是不及sql強大,見到報表等變態需求時,hql也歇菜,也就是說hql是有侷限的;hibernate雖然也支援原生sql,但開發模式上卻與orm不同,需要轉換思維,因此使用上不是非常方便。總之寫sql的靈活度上hibernate不及mybatis。

(6)快取機制上,hibernate要比mybatis更好一些

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

而Hibernate對查詢物件有著良好的管理機制,使用者無需關心SQL。所以在使用二級快取時如果出現髒資料,系統會報出錯誤並提示。

8、總結

(1)兩者相同點
Hibernate和Mybatis的二級快取除了採用系統預設的快取機制外,都可以通過實現你自己的快取或為其他第三方快取方案,建立介面卡來完全覆蓋快取行為。

(2)兩者不同點
Hibernate的二級快取配置在SessionFactory生成的配置檔案中進行詳細配置,然後再在具體的表-物件對映中配置是那種快取。而MyBatis在使用二級快取時需要特別小心。如果不能完全確定資料更新操作的波及範圍,避免Cache的盲目使用。否則,髒資料的出現會給系統的正常執行帶來很大的隱患。

(3)舉個形象的比喻

MyBatis:機械工具,使用方便,拿來就用,但工作還是要自己來作,不過工具是活的,怎麼使由我決定。(小巧、方便、高效、簡單、直接、半自動)

Hibernate:智慧機器人,但研發它(學習、熟練度)的成本很高,工作都可以擺脫他了,但僅限於它能做的事。(強大、方便、高效、複雜、繞彎子、全自動)