Java開發中,MyBatis、Hibernate、Spring Data JPA應該如何選擇?

AnitaSong


選擇哪一種框架,需要結合項目實際來,結合業務場景和團隊成員的能力,綜合考慮並選擇技術方案。

先和大家講講每一種框架是啥

  • Hibernate:POJO與數據庫表建立映射關係;Java程序員可以使用操作對象的思維操作數據庫。(POJO就是Java Bean,只有有屬性、set、get方法)

  • Mybatis:做的是POJO與SQL之間的映射關係;程序員需要編寫SQL;

  • Spring Data JPA:有人說它是對Hibernate更高級的封裝,這種說法是有一些問題的;第二部分詳細說明一下。

要解釋清楚Spring Data JPA是什麼,需要一步步說起

  • 期初Java需要通過各個數據庫廠商提供的API進行數據庫的訪問,後來JAVA提出了JDBC,程序直接使用JDBC這套規範就可以跟各個數據庫進行對接;

  • 接著誕生了ORM技術,簡化了Java對象的持久化工作,出現了Hibernate、TopLink等ORM框架;

  • Sun公司在JDK1.5的時候,吸收了Hibernate、TopLink等ORM框架的優點,提出了Java持久化規範:JPA;

  • Hibernate在3.2的時候提供了JPA的實現,其餘的JPA的供應商還有諸如OpenJPA、Toplink等;

  • Spring在做持久化這一塊的工作,開發了Spring-data-xxx這一系列包,如:Spring-data-jpa,Spring-data-redis,Spring-data-mongodb等等,這些都是Spring 提供的基於JPA和其他一些NOSQL的Repository。

  • Spring data JPA 是在JPA規範的基礎下提供了Repository層的實現,但是使用哪一款ORM需要你自己去決定;相比我們更為熟悉的Hibernate和MyBatis,Spring Data JPA可以看做更高層次的抽象。


  • 使用Spring data JPA,默認底層是Hibernate,但是可以修改成其他的ORM框架。

幾種框架的優劣

  • Hibernate開發難度較大,學習週期長;但是可以讓開發者無需關心SQL,更專注業務流程;HQL不關心數據庫的類型,所以遷移起來很方便;

  • Mybatis需要手動編寫SQL語句(更直觀),可更直接地對SQL進行優化,但是數據庫移植性差;

  • Spring Data JPA簡化了數據庫訪問,可以通過命名規範編寫SQL,如果SQL較為複雜,還是需要通過註解的方式編寫SQL;它更適用於現在微服務的架構(微服務的極致都是單表操作)。


從個人的角度:MyBatis>Spring Data JPA>Hibernate,或者MyBatis + Spring Data JPA。

我將持續分享Java開發、架構設計、程序員職業發展等方面的見解,希望能得到你的關注。


會點代碼的大叔


如果沒有更換不同數據庫可能,Mybatis 可能更好一些,現在的Mybatis不光只有原生,什麼操作都得寫SQL了,自動增刪改查單表的插件也很多了,而且自動分頁插件也有,都挺優秀。關於Hibernate和Spring Data Jpa本質基本一樣,Hibernate是JPA標準的一種實現,同為JPA實現的還有Eclipselink 、OpenJPA。這樣Hibernate就是Spring Data Jpa的默認執行器,同時Spring Data Jpa也有Eclipselink的實現,在實際使用中JPQL(HQL)會出現方法不足的情況最後還是得用SQL,比如像xxx,xxx,xxx這樣的數據,JPA和HQL中沒有實現,但是在MySQL中有一個find in set方法。


無名103905306


mybatis這就是趨勢。


程序員江湖


JPA: J2EE數據持久化的規範

JPA規範實現:Hibernate

Spring Data JPA: 本質也是藉助Hibernate實現JPA規範,並提供了很多數據庫交互的接口,容易快速上手

hibernate相比mybatis較重,如果只是簡單業務藉助於HQL語言可以提高開發效率。mybatis相比hibernate比較靈活,近乎原生的sql操作,處理複雜邏輯或者sql調優優勢巨大,目前我接觸的IT公司基本清一色的mybatis


定格往憶


不要挑,老闆讓你用啥就用啥,要適應項目,而不是讓項目適應你的技術棧,技術迭代很快,得時時跟上,跟不上就要淘汰了,struts現在就很少有公司用了


1234578901234567890


首選mybatis簡單 能出活 易調試 交了貨 剩下時間想看哪個看哪個


918622880


感覺HIBERNATE有時事務管理有問題,久不久出現事務提交一半的情況,弄得現在提交時要加好多校驗,出血


追尋專注的雨星


個人覺得,…都行,


分享到:


相關文章: