JPA与ORM以及Hibernate

 

有没有办法让程序员彻底抛弃书写SQL思想,完全的使用面向对象思想开发软件呢?

需要一种可行的ORM框架。

什么是ORM

不同的数据库使用的SQL语法不同,比如PL/SQL(Oracle)和T/SQL(SQL SERVER);

同样的功能不同的数据库有不同的实现方式

程序过分依赖SQL对程序的移植性扩展维护等带来很大的麻烦。

ORM框架包括Entity EJB、Hibernate、iBATIS、TopLink等,很多公司还开发了自己的ORM框架来解决项目的持久化。然而每种ORM框架都有自己的语法,他们之间不能直接通用。

 

 

对开发者而言,很多数据库持久化的的操作都是类似的,项目中采取的框架不同会造成代码的重复性。那么有没有办法来改善这种情况呢?

回想JDBC可以作为为多种关系数据库提供相同的访问方式,使开发人员方便于编写数据库应用程序。那么是不是可以有一种规范可以像JDBC一样提供不同ORM框架的统一规范。

Sun公司为了简化现有Java EE和Java SE应用的对象持久化的开发工作整合ORM技术,结束现在Hibernate、iBATIS、TopLink等ORM框架各自为营的局面,提出了新的JPA ORM规范。

1)       JPA为POJO提供持久化标准规范。

2)       JPA的使用:

    Hibernate与TopLink以及OpenJpa都提供了JPA的实现。

3)       JPA主要技术:
     JPA的总体思想和现有Hibernate、TopLink、JDO等ORM框架大体一致。总的来说,JPA包括以下三方面的技术:

      A. ORM映射元数据:JPA通过注解XML描述映射关系,并将运行中的实体对象持久化到数据库中。

      B. JPA持久化API:使用面向对象的思想,操作实体对象,进行增删改查的操作。至于怎么操作,由框架思考这件事。这必将大大的节省了开发时间,提    高了开发效率。

      C.  查询语言:使用面向对象的思想避免了同程序的SQL语句产生交集

4)       JPA与Hibernate
     注意,前面说过了,JPA是统一了各种ORM框架的接口,所以说,可以把JPA理解为它并不是新的ORM框架,是接口,是规范,是工具。就像JDBC不是数据库一样,也没有办法代替数据库。同理,JPA也不是ORM框架,我们可以透过JPA使用各种ORM,实现各项目之间的移植性,这是做到低耦合、可扩展的程序设计。

HibernateORM框架,它实现了JPA的规范。

实现JPA接口也并不意味着可以替代Hibernate,Hibernate的索引功能,缓存功能并没有相应的接口,所以有些时候还是需要Hibernate的。但是!凡是JPA能实现的功能都用JPA来实现,以此来减少框架之间的耦合性

PS:本人也在不断的学习中,这是在翻看了各种Hibernate,ORM,JPA资料后做出的总结,如果有不恰当的地方欢迎指出,大家互相交流,共同进步!

posted @ 2016-03-10 15:08  景行彼高松  阅读(2678)  评论(0编辑  收藏  举报