`

JPA会是ORM的王道吗?

阅读更多

JPA会是ORM的王道吗?

近几年持久化技术领域异常喧嚣,各种框架雨后春笋般地冒出。例如Spring对多个持久化技术提供了集成的支持,还通过Spring JDBC框架对JDBC API进行简化。Sun也连接不断地颁布几个持久化规范,如JPA(Java Persistence API)JPA作为Java EE 5.0平台标准的ORM规范,将得到所有Java EE服务器的支持。Sun这次吸取了之前EJB规范惨痛失败的经历,在充分吸收现有ORM框架的基础上,得到了一个易于使用、伸缩性强的ORM规范。从目前的开发社区的反应上看,JPA受到了极大的支持和赞扬,JPA作为ORM领域标准化整合者的目标应该不难实现。

一、 引子

荀子在《荀子·王制》中有云:王夺之人,霸夺之与,强夺之地。什么叫王道?就是仁义,以德待人,把人感动得甘心情愿认你当老大。什么叫霸道?就是你有实力,以力服人,谁不服就把他打服为止。从哲学上说,王道是正道,当然正道须以实力为基础。王道中也包含霸道,但王道顺势而行。

最近,笔者查看了JPAjava 持久性API)的相关规范,作为EJB3.0的重要组成部分,JPA还是很值得关注的。看完规范,感觉JPA还是比较的单一,其目标就是实现Java 持久性的通用。JPA采用纯POJO的方式实现,更多的是采用Java 5注释(Annotation),它利用 Java 5 中的注释和对象/关系映射,为数据持久化提供了更简单、易用的编程方式。JPA的优势是多供应商的支持,可以运行在容器之中,也可以运行于容器之外,这就是其显著的优点。

Java™ Platform Enterprise Edition (Java EE 5)的设计方法,充分利用了 Enterprise JavaBeans™ (EJB) 3.0 新的 Java Persistence API (JPA)特性。JPA 提供了一种标准的对象关系映射解决方案,该解决方案避免了依赖第三方框架(如 Hibernate)。Java EE 5 许多新功能都包含在经过修补的 EJB 架构中,其突出特性之一是 JPA。由于具有容器内和容器外持久性选项,JPA J2EE 软件架构师带来一系列全新设计选择。

JPA受到了极大的支持和赞扬,那到JPA作为ORM领域标准化整合者的目标应该能实现吗?能成来ORM的王道吗?

二、 JPA来了

JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中,图 1很好地描述了JPA的结构:


1.JPA的结构图

Sun引入新的JPA ORM规范出于两个原因:其一,简化现有Java EEJava SE应用的对象持久化的开发工作;其二,Sun希望整合对ORM技术,实现天下归一。

JPAEJB 3.0软件专家组开发,作为JSR-220实现的一部分。但它不囿于EJB 3.0,你可以在Web应用、甚至桌面应用中使用。JPA的宗旨是为POJO提供持久化标准规范,由此可见,经过这几年的实践探索,能够脱离容器独立运行,方便开发和测试的理念已经深入人心了。目前Hibernate 3.2TopLink 10.1.3以及OpenJPA都提供了JPA的实现。

JPA的总体思想和现有HibernateTopLinkJDOORM框架大体一致。总的来说,JPA包括以下3方面的技术:

ORM映射元数据,JPA支持XMLJDK 5.0注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中;

JPA API,用来操作实体对象,执行CRUD操作,框架在后台替我们完成所有的事情,开发者从繁琐的JDBCSQL代码中解脱出来。

查询语言,这是持久化操作中很重要的一个方面,通过面向对象而非面向数据库的查询语言查询数据,避免程序的SQL语句紧密耦合。

三、 JPA的优势

1 标准化

JPA JCP 组织发布的 Java EE 标准之一,因此任何声称符合 JPA 标准的框架都遵循同样的架构,提供相同的访问 API,这保证了基于JPA开发的企业应用能够经过少量的修改就能够在不同的JPA框架下运行。

2 对容器级特性的支持

JPA 框架中支持大数据集、事务、并发等容器级事务,这使得 JPA 超越了简单持久化框架的局限,在企业应用发挥更大的作用。

3 简单易用,集成方便

JPA的主要目标之一就是提供更加简单的编程模型:在JPA框架下创建实体和创建Java 类一样简单,没有任何的约束和限制,只需要使用 javax.persistence.Entity进行注释;JPA的框架和接口也都非常简单,没有太多特别的规则和设计模式的要求,开发者可以很容易的掌握。JPA基于非侵入式原则设计,因此可以很容易的和其它框架或者容器集成。

4 可媲美JDBC的查询能力

JPA的查询语言是面向对象而非面向数据库的,它以面向对象的自然语法构造查询语句,可以看成是Hibernate HQL的等价物。JPA定义了独特的JPQLJava Persistence Query Language),JPQLEJB QL的一种扩展,它是针对实体的一种查询语言,操作对象是实体,而不是关系数据库的表,而且能够支持批量更新和修改、JOINGROUP BYHAVING 等通常只有 SQL 才能够提供的高级查询特性,甚至还能够支持子查询。

5 支持面向对象的高级特性

JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,这样的支持能够让开发者最大限度的使用面向对象的模型设计企业应用,而不需要自行处理这些特性在关系数据库的持久化。

四、 JPA的供应商

JPA 的目标之一是制定一个可以由很多供应商实现的API,并且开发人员可以编码来实现该API,而不是使用私有供应商特有的API。因此开发人员只需使用供应商特有的API来获得JPA规范没有解决但应用程序中需要的功能。尽可能地使用JPA API,但是当需要供应商公开但是规范中没有提供的功能时,则使用供应商特有的API

1 Hibernate

JPA是需要Provider来实现其功能的,Hibernate就是JPA Provider中很强的一个,目前来说应该无人能出其右。从功能上来说,JPA现在就是Hibernate功能的一个子集。Hibernate 3.2开始,就开始兼容JPAHibernate3.2获得了Sun TCKJPA(Java Persistence API) 兼容认证。

只要熟悉Hibernate或者其他ORM框架,在使用JPA时会发现其实非常容易上手。例如实体对象的状态,在Hibernate有自由、持久、游离三种,JPA里有newmanageddetachedremoved,明眼人一看就知道,这些状态都是一一对应的。再如flush方法,都是对应的,而其他的再如说Query query = manager.createQuery(sql),它在Hibernate里写法上是session,而在JPA中变成了manager,所以从HibernateJPA的代价应该是非常小的

同样,JDO,也开始兼容JPA。在ORM的领域中,看来JPA已经是王道,规范就是规范。在各大厂商的支持下,JPA的使用开始变得广泛。

2 Spring

Spring+Hibernate常常被称为JavaWeb应用人气最旺的框架组合。而在JCP通过的WebBeansJSR,却欲将JSF+EJB+JPA、来自JBossSeamSpring除外)的一些组件和EJB3(目前能够提供有基本拦截和依赖注入功能的简化SessionBean框架)的一个Web组合进行标准化。如今的Spring2.0JPA提供了完整的EJB容器契约,允许JPA在任何环境内可以在Spring管理的服务层使用(包括Spring的所有AOPDI增强)。同时,关于下一个Web应用组合会是EJBSpring+Hibernate还是Spring+JPA的论战,早已充斥于耳。

Spring 2.0.1中,正式提供对JPA的支持,这也促成了JPA的发展,要知道JPA的好处在于可以分离于容器运行,变得更加的简洁。

3 OpenJPA

OpenJPA Apache 组织提供的开源项目,它实现了 EJB 3.0 中的 JPA 标准,为开发者提供功能强大、使用简单的持久化数据管理框架。OpenJPA 封装了和关系型数据库交互的操作,让开发者把注意力集中在编写业务逻辑上。OpenJPA 可以作为独立的持久层框架发挥作用,也可以轻松的与其它 Java EE 应用框架或者符合 EJB 3.0 标准的容器集成。

4 其它

目前支持的实现包括ToplinkHibernate Entitymanager等。TopLink以前需要收费,如今开源了。OpenJPA虽然免费,但功能、性能、普及性等方面更加需要加大力度。

对于EJB来说,实体Bean一直是被批评的对象,由于其太复杂和庞大。JPA的出现,很大程度的分离了复杂性。这让EJB的推广也变得容易。

总而言之,JPA规范主要关注的仅是API的行为方面,而由各种实现完成大多数性能有关的调优。尽管如此,所有可靠的实现都应该拥有某种数据缓存,以作为选择。但愿不久的将来,JPA能成为真正的标准。

五、 小结

EJB 3.0JPA 毫无疑问将是Java EE 5的主要卖点。在某些领域中,它们给Java社区带来了竞争优势,并使Java 在其他领域与竞争对手不分伯仲(因为,不可否认,目前某些领域尚不存在基于标准的方法)。

过去数年来,Spring Framework一直是EJB在企业领域的主要竞争对手。EJB3.0规范解决了很多促进Spring兴起的问题。随着它的出现,EJB3.0毫无疑问比Spring提供了更好的开发体验——最引人注目的优势是它不需要配置文件。

JPA提供一种标准的OR映射解决方案,该解决方案完全集成到EJB30兼容的容器中。JPA的前辈将会继续稳定发展,但是业务应用程序中的 raw 使用将可能会减少。实现 JPA 兼容的实体管理器似乎很可能是此类技术的发展方向。

Java EE系列规范的较大问题与JPA没有任何关系。Java EE 系列规范的问题涉及到 WebEJB容器之间的集成。Spring在此领域仍然具有主要竞争优势。JBossSeam项目尝试使用自定义的方法来解决这一问题。Caucho Resin应用服务器试图扩展容器边界并支持在Web容器中使用@EJB注释。我们希望Java EE 5.1将解决层集成的问题,为我们提供一个全面而标准的依赖性注入方法。

在不久的将来,Sun可能会将JPA作为一个单独的JSR对待,同时JPA还可能作为Java SE的一部分。不过这些都不太重要,重要的是,我们现在已经可以在脱离容器的情况下、在Java SE应用中使用JPA了。

JPA已经作为一项对象持久化的标准,不但可以获得Java EE应用服务器的支持,还可以直接在Java SE中使用。开发者将无需在现有多种ORM框架中艰难地选择,按照Sun的预想,现有ORM框架头顶的光环将渐渐暗淡,不再具有以往的吸引力。


转自:http://tech.it168.com/j/2007-09-24/200709241207013.shtml

分享到:
评论

相关推荐

    study-orm-jpa:Java ORM标准JPA编程学习项目

    Java ORM标准JPA编程学习项目 教科书: ://www.yes24.com/24/Goods/19040233?Acode = 教科书示例: : 1.项目说明 JDK 1.8标准 嵌入式Tomcat 8.0 Spring Data JPA 2.学习方法 注意:请使用三色笔学习方法( ) ...

    jpa例子jpajpa

    **Java Persistence API (JPA)** 是Java平台上的一个标准,用于管理关系数据库中的对象-关系映射(ORM)。它提供了一种方式,让开发者可以用面向对象的编程模型来操作数据库,而无需直接编写SQL语句。JPA允许你在...

    JPA_由数据库生成JavaBean

    JPA的主要目标是简化数据访问层的开发,减少对象-关系映射(ORM)的工作量。 在标题和描述中提到的"JPA_由数据库生成JavaBean",是指JPA提供的一项功能,即反向工程(Reverse Engineering),可以从现有的数据库...

    Springboot中使用Druid+JPA

    Druid是一个功能强大的数据库连接池,而JPA(Java Persistence API)是Java平台上的一个标准,用于对象关系映射(ORM)。本篇文章将深入探讨如何在Spring Boot项目中结合使用Druid和JPA进行数据库操作。 首先,我们...

    自己开发了一个小型ORM项目

    在生成的实现中,会使用ORM的核心逻辑来执行SQL语句,完成数据的增删改查。 ORM的核心在于映射规则,也就是如何将对象的属性与数据库表的列对应起来。常见的映射方式有注解映射和XML配置文件映射。在注解映射中,...

    JPA持久化简介

    Hibernate、iBATIS、TopLink、Castor JDO、Apache OJB等这么多持久层框架,你还在为学习上面那个框架而苦恼吗?你还为研究下一代是那个而头疼吗?...朋友,学习JPA吧!JPA的出现就是解决您上面的苦恼的。

    Java术语详解(JMS、RPC、Ajax、SOAP、WSDL、JPA、ORM、mvc和JNDI)

    JPA是Java实现ORM的一种方式,还有Hibernate等第三方库也是ORM的典型代表。 8. **MVC(Model-View-Controller)** MVC是一种软件设计模式,广泛应用于Web开发中。它将应用程序分为三个主要组件:模型(Model)负责...

    JPA(Java Persistence API) 是JavaEE5.0 平台标准的ORM规范

    ### JPA(Java Persistence API) 是JavaEE5.0 平台标准的ORM规范 #### 概述 JPA(Java Persistence API)是Java EE 5.0平台中定义的标准对象关系映射(ORM)规范,它允许开发人员将应用程序中的实体对象与数据库中...

    快速学习-Spring Data JPA 之 ORM概述

    第1章 ORM概述[了解] ORM(Object-Relational Mapping) 表示对象关系映射。在面向对象的软件开发中,通过ORM,就可以把对象映射到关系型数据库中。只要有一套程序能够做到建立对象与数据库的...而使用ORM则会大大减少

    Spring Boot JPA如何把ORM统一起来

    Spring Boot JPA 提供了一种高效且简便的方式来整合ORM(对象关系映射)框架,使得在Java应用中处理数据变得更加简单。ORM框架如Hibernate、TopLink和JDO等,允许开发者将面向对象的模型直接映射到关系数据库,从而...

    EJB+JSF+JPA全JAVAEE视频教程

    EJB+JSF+JPA全JAVAEE视频教程,EJB+JSF+JPA入门觉得有点难吗?JBOSS报错?该教程全程教你学习搭建EJB+JSF+JPA框架!!!

    JPA教程,包括TOPLink JPA,Hibernate JPA,Open Jpa,jpa批注

    OpenJPA是由Apache软件基金会开发的开源JPA实现。它是一个轻量级、高性能的解决方案,设计目标是简化Java应用的持久化层开发。OpenJPA具有良好的可扩展性,支持动态元数据源,允许开发者在运行时调整数据映射。同时...

    EJB3.0_Bacic(JPA).rar_orm

    **EJB3.0基础知识与JPA ORM映射详解** EJB(Enterprise JavaBeans)是Java平台上用于构建可部署的企业级应用的一种组件模型。EJB3.0是其一个重要版本,发布于2006年,它在前一版本的基础上进行了重大改进,引入了...

    sqltoy-orm是比JPA+MyBatis更加贴合项目的orm框架(依赖spring)

    SqlToy-ORM是一款高度贴合项目需求的ORM(Object-Relational Mapping)框架,它在设计上兼顾了JPA(Java Persistence API)的便捷性和MyBatis的灵活性与高性能。这款框架尤其适合那些依赖Spring生态系统的Java应用,...

    JPA学习文档笔记

    - **兼容性**: 在使用JPA开发的应用中,仍然会用到如Hibernate这样的ORM框架,但这些应用可以在不修改代码的情况下在任何支持JPA的环境中运行。 - **区别与联系**: JPA规定了标准接口和行为,而实际的实现是由如...

    JPA注解 和hibernate 建表

    JPA注解和Hibernate建表 ...JPA提供了一些注解来描述实体Bean的持久化信息,而Hibernate是一个基于JPA规范的ORM框架。通过配置persistence.xml和hibernate.cfg.xml文件,可以实现数据库的持久化和访问。

    JPA源文件/jpa学习

    JPA是Java EE和Java SE环境中的一种ORM(Object-Relational Mapping)解决方案,旨在替代Hibernate等第三方库,提供更加标准化的持久化框架。 **JPA规范**定义了应用程序与数据库交互的一组接口和API,包括实体...

Global site tag (gtag.js) - Google Analytics