简单条件查询
简单条件查询:查询某一个实体类或者集合 
按照Spring Data 的规范查询方法find | read | get 开头, 
涉及条件查询时,条件的属性用条件关键字连接,要注意的是:条件属性以首字母大写 
例如:定义一Entity实体类 
classUser{ 
  private StringfirstName
  private StringlastName
} 
使用And条件连接时,应这样写: 
findByLastNameAndFirstName(StringlastName,StringfirstName); 
条件的属性名称与个数要与参数的位置与个数一一对应 

支持的关键字
直接在接口中定义查询方法,如果是符合规范的,可以不用写实现,目前支持的关键字写法如下:

SpringData 方法定义规范

SpringData 方法定义规范

查询方法解析流程

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

相关文章:

  • 2022-12-23
  • 2021-12-09
  • 2022-12-23
  • 2021-10-25
  • 2021-10-30
  • 2022-12-23
猜你喜欢
  • 2022-01-14
  • 2021-07-08
  • 2022-12-23
  • 2021-07-01
  • 2021-11-21
相关资源
相似解决方案