SpringData查询过程解析
来源:互联网 发布:苹果数据接口转usb 编辑:程序博客网 时间:2024/06/07 23:23
SpringData在查询的过程中并没有出现Sql语句,它是如何实现查询。
解析如下:
假如创建如下的查询: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()"
特殊的参数: 还可以直接在方法的参数上加入分页或排序的参数,比如:1.Page<UserModel> findByName(String name, Pageable pageable);
2.List<UserModel> findByName(String name, Sort sort);
阅读全文
0 0
- SpringData查询过程解析
- SpringData MongoDB模糊查询
- SpringData特有的查询
- SpringData JPA分页查询
- springdata实现过程
- SpringData JPA查询分页demo
- SpringData JPA查询分页demo
- 整理springdata mongodb 查询 一
- SpringData
- springData
- SpringData
- SpringData JPA多对一查询
- SpringData JPA 实现动态条件查询
- springdata mongodb 查询二(Aggregation)
- voltDB 查询语句解析过程 初步分析
- SpringData JPA @Query分页查询Exception问题解决方案
- SpringData 内置分页查询方法 (包含排序)
- Elasticsearch源码分析九--查询解析器QueryParser注册过程
- 设计模式-15-迭代子模式
- socket阻塞与非阻塞,同步与异步、I/O模型
- Trailing Zeroes (III)
- STL——序列式容器的总结
- 2017多校训练第二场 hdu6045 Is Derek lying
- SpringData查询过程解析
- BZOJ 2565: 最长双回文串 manacher
- 将集合中的学生信息按照学生的年龄升序排列
- web开发工具
- Abp项目InternalServerError,SimpleStringCipher.Decrypt()找不到
- 正则表达式
- C++多态
- IE浏览器下AJAX缓存问题导致数据不更新的解决办法
- android webview无法上传文件的解决方案