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,会发现有以下问题:
- jpa 中有的 Entity, Table , 在 hibernate 中也有,但是内容不同
- 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也可以根据实际情况,将数据库访问操作合成,尽量减少不必要的数据库操作请求