天天看点

Spring Data JPA的Repository接口

Repositity接口继承关系

Repository:空接口,表名任何继承它的均为仓库接口类

CrudRepository:继承Repository,实现了一组CRUD相关的方法

PagingAndSortingRepository:继承CrudRepository,实现了一组分页、排序相关的方法

JpaRepository:继承PagingAndSortRepository,实现一组JPA规范相关的方法

自定义的XxxRepository需要继承JpaRepository,这样该接口就具备了通用的数据访问控制层的能力。

继承接口就意味着有以下的方法

Spring Data JPA的Repository接口

如下代码所示,前提再实体层有User类

@Test
public void testBaseQuery() throws Exception {
    User user=new User();
    userRepository.findAll();
    userRepository.findOne(1l);
    userRepository.save(user);
    userRepository.delete(user);
    userRepository.count();
    userRepository.exists(1l);
    // ...

           

JpaRepository查询方法解析流程

JPA方法名解析流程

  1. Spring Data JPA框架在进行方法名解析时,会先把方法名多余的前缀截取掉比如find、findBy、read、readBy、get、getBy,然后对剩下部分进行解析。
  2. 假如创建如下的查询:findByUserDepUuid(),框架在解析该方法时,首先剔除findBy,然后对剩下的属性进行解析,假设查询实体为Doc。
-- 1.先判断userDepUuid (根据POJO(Plain Ordinary Java Object简单java对象,实际就是普通java bean)规范,首字母变为小写。)是否是查询实体的一个属性,如果根据该属性进行查询;如果没有该属性,继续第二步。

-- 2.从右往左截取第一个大写字母开头的字符串(此处为Uuid),然后检查剩下的字符串是否为查询实体的一个属性,
如果是,则表示根据该属性进行查询;如果没有该属性,则重复第二步,继续从右往左截取;最后假设 user为查询实体的一个属性。

-- 3.接着处理剩下部分(DepUuid),先判断 user 所对应的类型是否有depUuid属性,
如果有,则表示该方法最终是根据 “ Doc.user.depUuid” 的取值进行查询;否则继续按照步骤 2 的规则从右往左截取,最终表示根据 “Doc.user.dep.uuid” 的值进行查询。

-- 4.可能会存在一种特殊情况,比如 Doc包含一个 user 的属性,也有一个 userDep 属性,此时会存在混淆。
可以明确在属性之间加上 "_" 以显式表达意图,比如 "findByUser_DepUuid()" 或者 "findByUserDep_uuid()"。