博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jpa 和 hibernate 的联系
阅读量:4166 次
发布时间:2019-05-26

本文共 2408 字,大约阅读时间需要 8 分钟。

JPA (Java Persistence API)            Persistence:可持续

Hibernate  是一个开放源代码的 ORM(对象关系映射)框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

JPA和Hibernate之间的关系

可以简单的理解为JPA是标准接口,Hibernate是实现:

Jpa是一种规范,而Hibernate是它的一种实现。

除了Hibernate,还有EclipseLink(曾经的toplink),OpenJPA等可供选择

所以使用Jpa的一个好处是,可以更换实现而不必改动太多代码。

那么Hibernate是如何实现与JPA的这种关系的呢。Hibernate主要是通过三个组件来实现的:

  •     hibernate-annotation
  •     hibernate-entitymanager
  •     hibernate-core

hibernate-annotation 是Hibernate支持annotation方式配置的基础,它包括了标准的JPA annotation以及Hibernate自身特殊功能的annotation。

hibernate-core 是Hibernate的核心实现,提供了Hibernate所有的核心功能。

hibernate-entitymanager 实现了标准的JPA,可以把它看成hibernate-core和JPA之间的适配器,它并不直接提供ORM的功能,而是对hibernate-core进行封装,使得Hibernate符合JPA的规范。

在play中定义Model时,使用的是jpa的annotations:

比如 javax.persistence.Entity, Table, Column, OneToMany等等。

但它们提供的功能基础,有时候想定义的更细一些,难免会用到Hibernate本身的annotation

但是如果想抛开 jpa,直接使用 hibernate 的注解来定义Model,会发现有以下问题:

  1. jpa 中有的 Entity, Table , 在 hibernate 中也有,但是内容不同
  2. jpa 中有 Column,OneToMany 等,Hibernate中没有,也没有替代品

我原以为hibernate对jpa的支持,是另提供了一套专用于jpa的注解,但现在看起来似乎不是。

一些重要的注解如Column, OneToMany等,hibernate没有提供,

这说明jpa的注解已经是hibernate的核心,hibernate只提供了一些补充,而不是两套注解。

  • 如果想用hibernate注解,是不是一定会用到jpa的。

网友的回答:“是。如果hibernate认为jpa的注解够用,就直接用。否则会弄一个自己的出来作为补充”

  • jpa和hibernate都提供了Entity,我们应该用哪个,还是说可以两个一起用?

网友回答说“Hibernate的Entity是继承了jpa的,所以如果觉得jpa的不够用,直接使用hibernate的即可”。

 

为什么要使用ORM技术

ORM 是Object-Relation-Mapping,即对象关系影射技术,是对象持久化的核心。

ORM是对JDBC的封装,从而解决了JDBC的各种存在问题:

a) 繁琐的代码问题

用JDBC的API编程访问数据库,代码量较大,特别是访问字段较多的表的时候,代码显得繁琐、累赘,容易出错。例如:PreparedStatement pstmt=con.prepareStatment("insert into account value(?,?,?,?,?,?,?,?,?)");

ORM则建立了Java对象与数据库对象之间的影射关系,程序员不需要编写复杂的SQL语句,直接操作Java对象即可,从而大大降低了代码量,也使程序员更加专注于业务逻辑的实现。

b) 数据库对象连接问题

关系数据对象之间,存在各种关系,包括1对1、1对多、多对1、多对多、级联等。在数据库对象更新的时候,采用JDBC编程,必须十分小心处理这些关系,以保证维持这些关系不会出现错误,而这个过程是一个很费时费力的过程。

ORM建立Java对象与数据库对象关系影射的同时,也自动根据数据库对象之间的关系创建Java对象的关系,并且提供了维持这些关系完整、有效的机制。

c) 系统架构问题

JDBC属于数据访问层,但是使用JDBC编程时,必须知道后台是用什么数据库、有哪些表、各个表有有哪些字段、各个字段的类型是什么、表与表之间什么关系、创建了什么索引等等与后台数据库相关的详细信息。

使用ORM技术,可以将数据库层完全隐蔽,呈献给程序员的只有Java的对象,程序员只需要根据业务逻辑的需要调用Java对象的Getter和 Setter方法,即可实现对后台数据库的操作,程序员不必知道后台采用什么数据库、有哪些表、有什么字段、表与表之间有什么关系。

d) 性能问题

采用JDBC编程,在很多时候存在效率低下的问题。

pstmt =conn.prepareStatement("insert into user_info values(?,?)");

       for (int i=0; i<1000; i++) {
          pstmt.setInt(1,i);
          pstmt.setString(2,"User"+i.toString());
          pstmt.executeUpdate();
       }

以上程序将向后台数据库发送1000次SQL语句执行请求,运行效率较低。

采用ORM技术,ORM框架将根据具体数据库操作需要,会自动延迟向后台数据库发送SQL请求,

ORM也可以根据实际情况,将数据库访问操作合成,尽量减少不必要的数据库操作请求

 

 

转载地址:http://kkgxi.baihongyu.com/

你可能感兴趣的文章
N 叉树的最大深度
查看>>
剑指 Offer 52. 两个链表的第一个公共节点 & 相交链表
查看>>
剑指offer 03.数组中的重复数字(四种办法!哎,就是全!)
查看>>
三层--对你的认识再多一点
查看>>
数据库初级篇--EA & ER & SQL Server
查看>>
离线安装.net framework3.5
查看>>
抽象工厂+反射(一)
查看>>
12月英语--Sowing
查看>>
泛型--datatable TO List
查看>>
存储过程
查看>>
C#之导出excel
查看>>
版本控制--SVN
查看>>
泛型 VS Data Table
查看>>
CSS盒子模型
查看>>
HTML总结(一)
查看>>
3月英语--平平淡淡
查看>>
csf格式转换--逼自己一把
查看>>
ASP控件总结(一)
查看>>
Repeater&Validator控件使用
查看>>
细水翻起半点波涛--4月英语
查看>>