1.Hibernate是全自動,而MyBatis是半自動。
Hibernate完全可以通過對象關(guān)系模型實現(xiàn)對數(shù)據(jù)庫的操作,擁有完整的JavaBean對象與數(shù)據(jù)庫的映射結(jié)構(gòu)來自動生成sql。而MyBatis僅有基本的字段映射,對象數(shù)據(jù)以及對象實際關(guān)系依然需要通過手寫sql來實現(xiàn)和管理。
2.Hibernate數(shù)據(jù)庫移植性遠大于MyBatis。
Hibernate通過它強大的映射結(jié)構(gòu)和hql語言,大大降低了對象與數(shù)據(jù)庫(Oracle、MySQL等)的耦合性,而MyBatis由于需要手寫sql,因此與數(shù)據(jù)庫的耦合性直接取決于程序員寫sql的方法,如果sql不具通用性而用了很多某數(shù)據(jù)庫騰訊的sql語句的話,移植性也會隨之降低很多,成本很高。
3.Hibernate擁有完整的日志系統(tǒng),MyBatis則欠缺一些。
Hibernate日志系統(tǒng)非常健全,涉及廣泛,包括:sql記錄、關(guān)系異常、優(yōu)化警告、緩存提示、臟數(shù)據(jù)警告等;而MyBatis則除了基本記錄功能外,功能薄弱很多。
4.MyBatis相比Hibernate需要關(guān)心很多細節(jié)。
Hibernate配置要比MyBatis復(fù)雜的多,學(xué)習(xí)成本也比MyBatis高。但也正因為MyBatis使用簡單,才導(dǎo)致它要比Hibernate關(guān)心很多技術(shù)細節(jié)。MyBatis由于不用考慮很多細節(jié),開發(fā)模式上與傳統(tǒng)jdbc區(qū)別很小,因此很容易上手并開發(fā)項目,但忽略細節(jié)會導(dǎo)致項目前期bug較多,因而開發(fā)出相對穩(wěn)定的軟件很慢,而開發(fā)出軟件卻很快。Hibernate則正好與之相反。但是如果使用Hibernate很熟練的話,實際上開發(fā)效率絲毫不差于甚至超過MyBatis。
5.sql直接優(yōu)化上,MyBatis要比Hibernate方便很多。
由于MyBatis的sql都是寫在xml里,因此優(yōu)化sql比Hibernate方便很。而Hibernate的sql很多都是自動生成的,無法直接維護sql;雖有hql,但功能還是不及sql強大,見到報表等變態(tài)需求時,hql也歇菜,也就是說hql是有局限的;Hibernate雖然也支持原生sql,但開發(fā)模式上卻與orm不同,需要轉(zhuǎn)換思維,因此使用上不上非常方便。總之寫sql的靈活度上Hibernate不及MyBatis。