第六节 JPA vs MyBatis
除了JPA
之外,还有一个流行的数据访问框架MyBatis
,算是个半自动化的ORM
框架。
1. JPA和MyBatis的比较
JPA
是个全自动化的对象持久化规范,它使得开发人员只需要针对领域模型编写面向对象的代码,而不必关心底层数据存储和SQL
查询;而MyBatis
则是一个能够灵活编写SQL
语句,并将SQL
的入参和查询结果映射成POJOs
的一个持久层框架。所以,从表面上看,JPA
能方便、自动化更强,而MyBatis
在SQL
语句编写方面则更灵活自由。
本质上看,JPA
是面向对象的,而MyBatis
是面向关系的。换言之,JPA
是以面向对象的领域模型为中心的,而MyBatis
是以数据库为中心的。领域模型致力于解决业务逻辑问题,而关系模型致力于解决数据的高效存取问题。
优缺点比较:
- JPA/Hibernate更自动化而MyBatis更灵活。
- 某些情况下,MyBatis性能比JPA/Hibernate更好。
- JPA支持面向对象的继承概念,支持继承映射、多态关联和多态查询,而MyBatis完全不支持。这一点是MyBatis的最大劣势。
- MyBatis会助长“以数据库为中心”的设计范式。
3. 国人钟情于Mybatis,而老外却喜欢Hibernate/JPA
在国际上,JPA/Hibernate
非常流行,而MyBatis
很少人使用。以下图表来自2018年JVM 生态报告:(https://snyk.io/blog/jvm-ecosystem-report-2018-platform-application/)
JPA
的实现框架Hibernate
的占比达到惊人的54%,而MyBatis
占比只有区区6%。
广泛使用MyBatis
的地区主要是中日韩三国。