Spring data jpa入门教程

Spring Data框架和Spring Data JPA简介

Spring Data : Spring 的一个子项目。用于简化数据库访问,支持NoSQL 和 关系数据存储。
下面给出SpringData 项目所支持 NoSQL 存储:
MongoDB (文档数据库)
Neo4j(图形数据库)
Redis(键/值存储)
Hbase(列族数据库)

SpringData 项目所支持的关系数据存储技术:
JDBC
JPA

JPA Spring Data : 致力于减少数据访问层 (DAO) 的开发量。开发者只要写好持久层接口就好,然后其它的框架会帮程序员实现。

Spring Data JPA例子

实现步骤:
1.配置 Spring 整合 JPA
2.在 Spring 配置文件中配置 Spring Data,让 Spring 为声明的接口创建代理对象。
3.声明持久层的接口,该接口继承 Repository
4.在接口中声明需要的方法

同时下载 Spring Data Commons 和 Spring Data JPA 两个发布包,也可以在maven里配置

<dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-jpa</artifactId>
            <version>${spring-data-jpa.version}</version>
        </dependency>

写个接口Repository:

public interface UserRepository extends Repository<User,Integer>{
    User getByUserId(Integer id);
}

Repository接口概述:
(1)Repository 接口是 Spring Data 的一个核心接口,它不提供任何方法,开发者需要在自己定义的接口中声明需要的方法
public interface Repository<T, ID extends Serializable> { }
(2)Spring Data可以让我们只定义接口,只要遵循 Spring Data的规范,就无需写实现类。
(3)与继承 Repository 等价的一种方式,就是在持久层接口上使用 @RepositoryDefinition 注解,并为其指定 domainClass 和 idClass 属性。如下两种方式是完全等价的

Repository子接口
基础的Repository提供了最基本的数据访问功能,其几个子接口则扩展了一些功能。

按照 Spring Data 的规范,查询方法以 find | read | get 开头, �涉及条件查询时,条件的属性用条件关键字连接,要注意的是:条件属性以首字母大写。

查询方法解析

假如创建如下的查询:findByUserDepUuid(),框架在解析该方法时,首先剔除 findBy,然后对剩下的属性进行解析,假设查询实体为Doc
(1)先判断 userDepUuid (根据 POJO 规范,首字母变为小写)是否为查询实体的一个属性,如果是,则表示根据该属性进行查询;如果没有该属性,继续第二步;
(2)从右往左截取第一个大写字母开头的字符串(此处为Uuid),然后检查剩下的字符串是否为查询实体的一个属性,如果是,则表示根据该属性进行查询;如果没有该属性,则重复第二步,继续从右往左截取;最后假设 user 为查询实体的一个属性;
(3)接着处理剩下部分(DepUuid),先判断 user 所对应的类型是否有depUuid属性,如果有,则表示该方法最终是根据 “ Doc.user.depUuid” 的取值进行查询;否则继续按照步骤 2 的规则从右往左截取,最终表示根据 “Doc.user.dep.uuid” 的值进行查询。
(4)可能会存在一种特殊情况,比如 Doc包含一个 user 的属性,也有一个 userDep 属性,此时会存在混淆。可以明确在属性之间加上 "_" 以显式表达意图,比如 "findByUser_DepUuid()" 或者 "findByUserDep_uuid()"
特殊的参数: 还可以直接在方法的参数上加入分页或排序的参数,比如:
Page<UserModel> findByName(String name, Pageable pageable);
List<UserModel> findByName(String name, Sort sort);

使用 @Query 注解

@Query来指定本地查询
注意要点

如果是 @Query 中有 LIKE 关键字,后面的参数需要前面或者后面加 %,这样在传递参数值的时候就可以不加 %:

@Query("select o from UserModel o where o.name like %?1")

使用@Query来指定本地查询,只要设置nativeQuery为true

@Query(value="select * from tbl_user where name like %?1" ,nativeQuery=true)

@Query 与 @Modifying 这两个 annotation一起声明,可定义个性化更新操作,例如只涉及某些字段更新时最为常用

Spring Data 提供了默认的事务处理方式,即所有的查询均声明为只读事务。

CrudRepository 接口

CrudRepository 接口提供了最基本的对实体类的添删改查操作

PagingAndSortingRepository接口

该接口提供了分页与排序功能
Iterable<T> findAll(Sort sort); //排序
Page<T> findAll(Pageable pageable); //分页查询(含排序功能)

JpaRepository接口

该接口提供了JPA的相关功能
List<T> findAll(); //查找所有实体
List<T> findAll(Sort sort); //排序、查找所有实体
List<T> save(Iterable<? extends T> entities);//保存集合
void flush();//执行缓存与数据库同步
T saveAndFlush(T entity);//强制执行持久化
void deleteInBatch(Iterable<T> entities);//删除一个实体集合

JpaSpecificationExecutor接口

不属于Repository体系,实现一组 JPA Criteria 查询相关的方法
注意也可以自定义Repository的方法

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 131,187评论 18 138
  • https://www.ibm.com/developerworks/cn/opensource/os-cn-sp...
    大同若鱼阅读 4,821评论 4 18
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 44,268评论 6 344
  • 简介: 本文由浅入深地讲述了使用 Spring Data JPA 需要关注的各个方面,为读者了解和使用该框架提供了...
    AiPuff阅读 4,221评论 1 28
  • 画画, 让孩子自由自在地表达真实的内心感受; 描绘神奇独特的心灵风景。 孩子的画, 对于爱他/她的爸爸妈妈来说, ...
    隽妈杂记阅读 510评论 0 0
  • 我曾停下匆忙的脚步只为瞩目你 你说那是山,便是山,你说那是海,便是海 山海皆可越,难得唯君心 我曾翻过山,越过海,...
    巧克力的倔强阅读 47评论 0 2
  • 佛家说:“死生事大,命在须臾。”可见,死和生是人生的大问题。 西方哲人认为,未知死,焉知生?所以,许多西方哲人都把...
    左手梦圆阅读 549评论 0 1
  • 我向着黑色的牵牛花祈祷 愿在时间静止的长河里 追逐你透明的影子 从激情烈火到三尺冰封 从醉生梦死到永恒一念 我追逐...
    皮糙肉薄阅读 54评论 0 3