Mybatis与Hibernate的详细对比
轉(zhuǎn)載自??Mybatis與Hibernate的詳細(xì)對比
前言
這篇博文我們重點(diǎn)分析一下Mybatis與Hibernate的區(qū)別,當(dāng)然在前面的博文中我們已經(jīng)深入的研究了Mybatis和Hibernate的原理。
Mybatis
Hibernate
作為一位優(yōu)秀的程序員,只知道一種ORM框架是遠(yuǎn)遠(yuǎn)不夠的。在開發(fā)項(xiàng)目之前,架構(gòu)的技術(shù)選型對于項(xiàng)目是否成功起到至關(guān)重要的作用。我們不僅要了解同類型框架的原理以及技術(shù)實(shí)現(xiàn),還要深入的理解各自的優(yōu)缺點(diǎn),以便我們能夠在項(xiàng)目的實(shí)施過程中面對的困難更少。
所以這篇博文我們要將Mybatis和Hibernate進(jìn)行一下深入的對比,加深我們對持久化框架的理解。下面我們開始今天的旅行。
Hibernate與Mybatis對比
1. 簡介
Hibernate:Hibernate是當(dāng)前最流行的ORM框架之一,對JDBC提供了較為完整的封裝。Hibernate的O/R Mapping實(shí)現(xiàn)了POJO 和數(shù)據(jù)庫表之間的映射,以及SQL的自動生成和執(zhí)行。
Mybatis:Mybatis同樣也是非常流行的ORM框架,主要著力點(diǎn)在于 POJO 與 SQL 之間的映射關(guān)系。然后通過映射配置文件,將SQL所需的參數(shù),以及返回的結(jié)果字段映射到指定 POJO 。相對Hibernate“O/R”而言,Mybatis 是一種“Sql Mapping”的ORM實(shí)現(xiàn)。
2. 開發(fā)速度
難易度
Hibernate的真正掌握要比Mybatis困難,Hibernate比mybatis更加重量級一些。
Mybatis框架相對簡單很容易上手,但也相對簡陋些。
開發(fā)工作量
Mybatis需要我們手動編寫SQL語句,回歸最原始的方式,所以可以按需求指定查詢的字段,提高程序的查詢效率。
Hibernate也可以自己寫SQL語句來指定需要查詢的字段,但這樣破壞了Hibernate封裝以及簡潔性。
3. 數(shù)據(jù)庫移植性
Mybatis由于所有SQL都是依賴數(shù)據(jù)庫書寫的,所以擴(kuò)展性,遷移性比較差。
Hibernate與數(shù)據(jù)庫具體的關(guān)聯(lián)都在XML中,所以HQL對具體是用什么數(shù)據(jù)庫并不是很關(guān)心。
4. 緩存機(jī)制對比
相同點(diǎn)
Hibernate和Mybatis的二級緩存除了采用系統(tǒng)默認(rèn)的緩存機(jī)制外,都可以通過實(shí)現(xiàn)你自己的緩存或?yàn)槠渌谌骄彺娣桨?#xff0c;創(chuàng)建適配器來完全覆蓋緩存行為。
不同點(diǎn)
Hibernate的二級緩存配置在SessionFactory生成的配置文件中進(jìn)行詳細(xì)配置,然后再在具體的表-對象映射中配置是那種緩存。
MyBatis的二級緩存配置都是在每個具體的表-對象映射中進(jìn)行詳細(xì)配置,這樣針對不同的表可以自定義不同的緩存機(jī)制。并且Mybatis可以在命名空間中共享相同的緩存配置和實(shí)例,通過Cache-ref來實(shí)現(xiàn)。
兩者比較
因?yàn)镠ibernate對查詢對象有著良好的管理機(jī)制,用戶無需關(guān)心SQL。所以在使用二級緩存時如果出現(xiàn)臟數(shù)據(jù),系統(tǒng)會報(bào)出錯誤并提示。而MyBatis在這一方面,使用二級緩存時需要特別小心。如果不能完全確定數(shù)據(jù)更新操作的波及范圍,避免Cache的盲目使用。否則,臟數(shù)據(jù)的出現(xiàn)會給系統(tǒng)的正常運(yùn)行帶來很大的隱患。
5. 兩者對比總結(jié)
兩者相同點(diǎn)
-
Hibernate與MyBatis都可以是通過SessionFactoryBuider由XML配置文件生成SessionFactory,然后由SessionFactory 生成Session,最后由Session來開啟執(zhí)行事務(wù)和SQL語句。其中SessionFactoryBuider,SessionFactory,Session的生命周期都是差不多的。如下圖所示:
- Hibernate和MyBatis都支持JDBC和JTA事務(wù)處理。
Hibernate優(yōu)勢
-
Hibernate的DAO層開發(fā)比MyBatis簡單,Mybatis需要維護(hù)SQL和結(jié)果映射。
-
Hibernate對對象的維護(hù)和緩存要比MyBatis好,對增刪改查的對象的維護(hù)要方便。
-
Hibernate數(shù)據(jù)庫移植性很好,MyBatis的數(shù)據(jù)庫移植性不好,不同的數(shù)據(jù)庫需要寫不同SQL。
-
Hibernate有更好的二級緩存機(jī)制,可以使用第三方緩存。MyBatis本身提供的緩存機(jī)制不佳。
Mybatis優(yōu)勢
-
MyBatis可以進(jìn)行更為細(xì)致的SQL優(yōu)化,可以減少查詢字段。
-
MyBatis容易掌握,而Hibernate門檻較高。
一句話總結(jié)
在博文的結(jié)尾,我們將Mybatis和Hibernate之間的區(qū)別自個用六個詞做總結(jié):
Mybatis:小巧、方便、高效、簡單、直接、半自動化
Hibernate:強(qiáng)大、方便、高效、復(fù)雜、間接、全自動化
版權(quán)聲明:本文為博主原創(chuàng)文章,未經(jīng)博主允許不得轉(zhuǎn)載。 https://blog.csdn.net/jiuqiyuliang/article/details/45378065
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎總結(jié)
以上是生活随笔為你收集整理的Mybatis与Hibernate的详细对比的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: i3组装电脑配置推荐(i3组装电脑配置)
- 下一篇: 程序员如何写简历?来自硅谷的八条建议