天天看点

JDBC和ORM和JPA和Spirng Data JPA的关系

参考链接:https://www.bilibili.com/video/BV1NJ411C7DQ?p=45

java操作数据库的原生API:jdbc。jdbc的作用是在java中执行SQL语句,这是java和数据库连接的最基本API,Hibernate和Mybatis这些都是对jdbc进行封装后的API。

请看下图:即使没有JPA(java持久化API),java依旧可以通过  jdbc API执行SQL语句 操作数据库。但是会出现操作繁琐等,需要写大量的SQL语句。

而Hibernate、Mybatis等持久化框架封装了jdbc API,因此java就可以通过Hibernate、Mybatis这些API操作数据库(不需要写大量的SQL语句)。但是java操作的是实体类对象,而数据库中存放的是表,如何将他们联系到一起对象和表联系到一起,即通过java对象操作数据库中的表呢?这是就需要ORM(对象关系映射)。

ORM思想:对象关系映射。主要目的:使得实体类对象和数据库中的表联系在一起。

ORM:Object-Relationl Mapping,它的作用是在关系型数据库和对象之间作一个映射,这样,我们在具体的操作数据库的时候,就不需要再去和复杂的SQL语句打交道,只要像平时操作对象一样操作它就可以了。

简单说:

1. 将关系型数据库中的数据和Java中对象建立映射关系

2. 避免了编写复杂的繁琐的SQL语句

3. 操作数据就像操作对象一样

主要建立两个映射关系:实体类和表的映射关系;实例类中属性和表的字段的映射关系。

实现了ORM思想的框架有:Hibernate和Mybatis等

JPA:前边说到,ORM是一种对象关系映射思想,而现在JPA(Java Persistence API(Java持久层API)针对这一思想提出了一种规范。因此叫做JPA规范。JPA描述对象关系映射,将运行期的实体对象持久化到数据库中,因此才叫java持久化API,而jdbc本身就是直接处理SQL语句的,本来就是持久化的。

JDBC和ORM和JPA和Spirng Data JPA的关系
JDBC和ORM和JPA和Spirng Data JPA的关系

Hibernate和Mybatis都是orm对象关系映射框架,都是用于将数据持久化的框架技术。

Hiberante较深度的封装了jdbc,对开发者写sql的能力要求的不是那么的高,我们只要通过hql语句操作对象即可完成对数据持久化的操作了。

另外hibernate可移植性好,如一个项目开始使用的是mysql数据库,但是随着业务的发展,现mysql数据库已经无法满足当前的绣球了,现在决定使用Oracle数据库,虽然sql标准定义的数据库间的sql语句差距不大,但是不同的数据库sql标准还是有差距的,那么我们手动修改起来会存在很大的困难,使用hibernate只需改变一下数据库方言即可搞定。用hibernate框架,数据库的移植变的非常方便。

但是hibernate也存在着诸多的不足,比如在实际开发过程中会生成很多不必要的sql语句耗费程序资源,优化起来也不是很方便,且对存储过程支持的也不够太强大。但是针对于hibernate它也提供了一些优化策略,比如说懒加载、缓存、策略模式等都是针对于它的优化方案。

Mybatis 也是对jdbc的封装,但是封装的没有hibernate那么深,我们可以再配置文件中写sql语句,可以根据需求定制sql语句,数据优化起来较hibernate容易很多。

Mybatis要求程序员写sql的能力要相对使用hibernate的开发人员要高的多,且可移植性也不是很好。

涉及到大数据的系统使用Mybatis比较好,因为优化较方便。涉及的数据量不是很大且对优化没有那么高,可以使用hibernate

JDBC和ORM和JPA和Spirng Data JPA的关系

理解了JPA规范,就好理解jdbc规范,定义好jdbc规范后,各个厂家就可以去实现相应的连接驱动了,比如mysql驱动,他们都遵循jdbc规范

JDBC接口(API)包括两个层次:

  • 面向应用的API:

    Java API

    ,抽象接口,供应用程序开发人员使用(连接数据库,执行SQL语句,获得结果)。
  • 面向数据库的API:

    Java Driver API

    ,供开发商开发数据库驱动程序用。

看看JDBC和JPA的区别:

文章开头我们就说过了,没有JPA,通过jdbc我们就可以实现一切,但是jdbc需要些大量SQL语句,太繁琐,于是我们想着能不能直接操作实体类来操作数据库,才出现了ORM思想,才有了JPA规范,才有了实现JPA规范的Hibernate和Mybatis,但是跟数据库交互的只能是jdbc规范,因此其实Hibernate和Mybatis这些框架封装了jdbc,底层其实就是jdbc,jpa实现的框架底层还是用jdbc去和数据库打交道。

  • 不同标准:jdbc是数据库的统一接口标准;jpa是orm框架的统一接口标准。
  • 用法区别:jdbc更注重数据库,orm则更注重于java代码,但是实际上jpa实现的框架底层还是用jdbc去和数据库打交道。
JDBC和ORM和JPA和Spirng Data JPA的关系
JDBC和ORM和JPA和Spirng Data JPA的关系

在真实开发过程中,我们只需要在dao层编写dao接口,不需要去编写具体的实现类。

JDBC和ORM和JPA和Spirng Data JPA的关系

原因是程序会通过  动态代理  生成接口的实现类对象。

JDBC和ORM和JPA和Spirng Data JPA的关系
JDBC和ORM和JPA和Spirng Data JPA的关系
JDBC和ORM和JPA和Spirng Data JPA的关系

继续阅读