MyBatis与Hibernate比较
MyBatis:
1.是一個sql語句映射的框架(工具)。
2.注重pojo與sql之間的映射關系。不會為程序員在運行期自動生成sql
3.自動化程度低,手工映射sql靈活程度高
4.需要開發人員熟練掌握sql語句
Hibernate:
1.主流的ORM框架,提供pojo到數據庫表的全套映射機制。
2.會自動生成全套sql語句。
3.因為自動化程度高,映射配置復雜,API也相對復雜,靈活性低。
4.開發人員不必關注sql底層語句開發
?
mybatis和hibernate一樣是個orm數據庫框架。
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不同,需要轉換思維,因此使用上不是非常方便??傊畬憇ql的靈 活度上hibernate不及mybatis。
轉載于:https://www.cnblogs.com/fifiyong/p/6307709.html
總結
以上是生活随笔為你收集整理的MyBatis与Hibernate比较的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Matlab Tricks(二十九) —
- 下一篇: 几种简单的排序算法(JAVA)