jpa 和 hibernate 的联系

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的即可”。

http://www.cnblogs.com/chengJAVA/p/3631264.html

 

为什么要使用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也可以根据实际情况,将数据库访问操作合成,尽量减少不必要的数据库操作请求

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

beOkWithAnything

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值