Spring Data JPA 使用感受
程序员文章站
2022-07-12 11:08:02
...
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提供的的接口方法:
2、遵循JPA规范,同时也提供了灵活的数据访问方式;
Spring Data JPA能够很好的兼容目前JPA2.0规范,在定义Entity类的时候,可以在类中定义标准的@NamedQuery查询,也可以在Spring Data JPA的Repository类的方法中定义@Query查询。
标准的JPA对@NamedQuery定义如下:
Spring Data JPA对@Query定义如下:
通过以上定义,在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是什么,简单的说,Spring Data JPA是Spring基于ORM框架、JPA规范的基础上封装的一套JPA应用框架,该框架有如下几个优点:
1、提供统一的接口,可避免我们再次重复编写基础的DAO类;
Spring Data JPA提供了几个基础的接口类,分别为CrudRepository、PagingAndSortingRepository、 Repository,其中,CrudRepository提供了基础的增删查改方法,PagingAndSortingRepository则在CrudRepository的基础上提供了对数据查询的分页支持,Repository建立在PagingAndSortingRepository的基础上,提供了完善的接口方法。
以先展示了CrudRepository提供的的接口方法:
public interface CrudRepository<T, ID extends Serializable> extends Repository<T, ID> { T save(T entity); T findOne(ID primaryKey); Iterable<T> findAll(); Long count(); void delete(T entity); boolean exists(ID primaryKey); // … more functionality omitted. }
2、遵循JPA规范,同时也提供了灵活的数据访问方式;
Spring Data JPA能够很好的兼容目前JPA2.0规范,在定义Entity类的时候,可以在类中定义标准的@NamedQuery查询,也可以在Spring Data JPA的Repository类的方法中定义@Query查询。
标准的JPA对@NamedQuery定义如下:
@Entity @NamedQuery(name="Country.findAll", query="SELECT c FROM Country c") public class Country { ... }
Spring Data JPA对@Query定义如下:
public interface CountryRepository extends JpaRepository<Country, Long> { @Query("SELECT c FROM Country c") Country findAll(); }
通过以上定义,在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/
上一篇: Spring Data JPA 介绍
下一篇: 冒泡排序 J#
推荐阅读
-
详解Spring Data JPA动态条件查询的写法
-
Spring Data JPA使用Sort进行排序(Using Sort)
-
详解Spring Data JPA系列之投影(Projection)的用法
-
详解Spring Data JPA使用@Query注解(Using @Query)
-
Spring Data JPA实现分页Pageable的实例代码
-
spring data jpa使用详解(推荐)
-
Spring Data JPA例子代码[基于Spring Boot、Mysql]
-
Spring-Data-JPA整合MySQL和配置的方法
-
在Spring Boot中使用Spring-data-jpa实现分页查询
-
序列化表单为json对象,datagrid带额外参提交一次查询 后台用Spring data JPA 实现带条件的分页查询 多表关联查询