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开发、架构设计、程序员职业发展等方面的见解,希望能得到你的关注。mysql 与或非,oracle mysql内存配置,mysql 8.0.11.tar.gz,ubuntu如何离线卸载mysql,mysql update 失效,mycat mysql 主从