JpaRepository的查询

 
image.png
 
image.png
Spring Data JPA框架在进行方法名解析时,会先把方法名多余的前缀截取掉,比如 find、findBy、read、readBy、get、getBy,然后对剩下部分进行解析。

假如创建如下的查询: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 findByName(String name, Pageable pageable);
List findByName(String name, Sort sort);

也可以使用JPA的NamedQueries,方法如下:

1:在实体类上使用@NamedQuery,示例如下:
@NamedQuery(name = "UserModel.findByAge",query = "select o from UserModel o where o.age >= ?1")

2:在自己实现的DAO的Repository接口里面定义一个同名的方法,示例如下:
public List findByAge(int age);

3:然后就可以使用了,Spring会先找是否有同名的NamedQuery,如果有,那么就不会按照接口定义的方法来解析。

作者:风丶无痕
链接:https://www.jianshu.com/p/2bd0f7f92b1d
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

最新文章

  1. css 内联元素
  2. 【读书笔记《Android游戏编程之从零开始》】4.Android 游戏开发常用的系统控件(EditText、CheckBox、Radiobutton)
  3. [接口服务] Jersey Rest Demo
  4. qt opencv
  5. 原生js实现tab选项卡里内嵌图片滚动特效代码
  6. js 模板引擎 - 超级强大
  7. hdu 1530 Maximum Clique
  8. win10 store 无法连接网络
  9. vue报错如log,如果其他项目运行没问题,很有可能是代码错误 加externals报错
  10. 云笔记项目-Spring事务学习-传播NEVER
  11. identityserver4 代码系列
  12. 阿里字体css代码引入方法
  13. django中命令行调试程序
  14. iOS Xcode Error 集锦
  15. 54.NSJSONSerialization类进行json解析(字符串“UTF-8解码”)
  16. json库的编译方法和vs2010中导入第三方库的方法
  17. Windows下搭建appium(Android版)
  18. C++解析(10):struct和class的区别
  19. javaScript语法和风格的检查工具
  20. CGameConfig类

热门文章

  1. ssh连接远程服务器出现Host key验证失败的解决方案
  2. redis 学习(11)-- redis pipeline
  3. node工具之http-proxy-middleware
  4. 关于Java HotSpot(TM) 64-Bit Server VM warning: Insufficient space for shared memory file: 11043的解决办
  5. python cv2读取rtsp实时码流按时生成连续视频文件
  6. 错误信息 NSError
  7. jumpserver开源堡垒机部署安装
  8. pg数据库data文件夹达到32G
  9. Linu目录结构和创建用户
  10. Linux inode 详解