Spring Data JPA 使用感受

来源:互联网 发布:喀秋莎视频剪辑软件 编辑:程序博客网 时间:2024/06/06 20:18
Spring Data JPA是Spring Data项目中的一个子项目,该子项目依赖于另外一个基础子项目Spring Data Commons。

首先谈一下Spring Data JPA是什么,简单的说,Spring Data JPA是Spring基于ORM框架、JPA规范的基础上封装的一套JPA应用框架,该框架有如下几个优点:

1、提供统一的接口,可避免我们再次重复编写基础的DAO类;
Spring Data JPA提供了几个基础的接口类,分别为CrudRepository、PagingAndSortingRepository、 Repository,其中,CrudRepository提供了基础的增删查改方法,PagingAndSortingRepository则在CrudRepository的基础上提供了对数据查询的分页支持,Repository建立在PagingAndSortingRepository的基础上,提供了完善的接口方法。

以先展示了CrudRepository提供的的接口方法:
Java代码  收藏代码
  1. public interface CrudRepository<T, ID extends Serializable>  
  2.     extends Repository<T, ID> {  
  3.                                                                                            
  4.     T save(T entity);  
  5.                                                                                            
  6.     T findOne(ID primaryKey);  
  7.                                                                                            
  8.     Iterable<T> findAll();  
  9.   
  10.     Long count();  
  11.                                                                                            
  12.     void delete(T entity);  
  13.                                                                                            
  14.     boolean exists(ID primaryKey);  
  15.                                                                                            
  16.     // … more functionality omitted.  
  17. }  


2、遵循JPA规范,同时也提供了灵活的数据访问方式;
Spring Data JPA能够很好的兼容目前JPA2.0规范,在定义Entity类的时候,可以在类中定义标准的@NamedQuery查询,也可以在Spring Data JPA的Repository类的方法中定义@Query查询。

标准的JPA对@NamedQuery定义如下:
Java代码  收藏代码
  1. @Entity  
  2. @NamedQuery(name="Country.findAll", query="SELECT c FROM Country c")   
  3. public class Country {  
  4.   ...  
  5. }  


Spring Data JPA对@Query定义如下:
Java代码  收藏代码
  1. public interface CountryRepository extends JpaRepository<Country, Long> {  
  2.   
  3.   @Query("SELECT c FROM Country c")  
  4.   Country findAll();  
  5. }  

通过以上定义,在Entity中即可省略掉@NamedQuery定义,让Entity类看起来更清爽。

3、通过方法名即可自动生成HQL语句;
如果你使用过Spring Data JPA,那么一定会对其提供的方法名自动转换为HQL感到十分有意思,这也是Spring Data JPA让人觉得很方便的地方,下面给两个转换规则的例子:
Keyword |          Sample               |                JPQL snippet
And     |  findByLastnameAndFirstname |… where x.lastname = ?1 and x.firstname = ?2
Or      |  findByLastnameOrFirstname    |… where x.lastname = ?1 or x.firstname = ?2

具体转换规则可参考官方文档。

4、通过接口自动注入实现类,实现非常简单。
我们只需要定义一个类似DAO的接口类,并继承Spring Data JPA提供的Repository接口类,一切就大功告成了,不需要编写任何一行代码,你的DAO接口类就具备了增删查改、分页、记录数统计等功能,对的,一切就那么简单!

以上是本人对Spring Data JPA使用上的一些感受,如果读者对其很感兴趣,可进一步阅读:
  • SPRING DATA - JPA项目首页http://www.springsource.org/spring-data
  • SPRING DATA - JPA参考手册http://static.springsource.org/spring-data/data-jpa/docs/current/reference/html/
  • GETTING STARTED WITH SPRING DATA JPAhttp://blog.springsource.com/2011/02/10/getting-started-with-spring-data-jpa/
原创粉丝点击