我的编程空间,编程开发者的网络收藏夹
学习永远不晚

spring data jpa怎么创建方法名进行简单查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

spring data jpa怎么创建方法名进行简单查询

本文小编为大家详细介绍“spring data jpa怎么创建方法名进行简单查询”,内容详细,步骤清晰,细节处理妥当,希望这篇“spring data jpa怎么创建方法名进行简单查询”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

spring data jpa 可以通过在接口中按照规定语法创建一个方法进行查询,spring data jpa 基础接口中,如CrudRepository中findOne,save,delete等,那么我们自己怎么按照需要创建一个方法进行查询呢?

最常见的做法是

声明一个接口继承于CrudRepository 或者 PagingAndSortingRepository,JpaRepository,Repository

public interface TaskDao extends JpaRepository<Task,Long>{}

或者利用注释的方式表名继承于JpaRepository,例如下面这俩种是等价的

@RepositoryDefinition(domainClass = Task.class, idClass = Long.class) public interface TaskDao{}public interface TaskDao extends JpaRepository<Task,Long>{}

继承CrudRepository 或者 PagingAndSortingRepository,JpaRepository会抽出一些常用的方法,如果你spring data jpa帮你自定义那么多方法,你可以继承于JpaRepository,然后复制一些方法到你的接口中,可以选择性的要一些方法

@NoRepositoryBeaninterface MyBaseRepository<T, ID extends Serializable> extends Repository<T, ID> {  T findOne(ID id);  T save(T entity);}interface TaskDao extends MyBaseRepository<Task, Long> {}

按照规范创建查询方法

一般按照java驼峰式书写规范加一些特定关键字,例如我们想通过任务名来获取任务实体类列表

利用属性获取任务列表

interface TaskDao extends MyBaseRepository<Task, Long> {  List<Task> findByName(String name);}

利用and 和 or来获取任务列表

interface TaskDao extends JpaRepository<Task, Long> {  List<Task> findByNameAndProjectId(String name,Long projectId);  List<Task> findByNameOrProjectId(String name,Long projectId);}

利用Pageable ,Sort,Slice获取分页的任务列表和排序

interface TaskDao extends JpaRepository<Task, Long> {  Page<Task> findByName(String name,Pageable pageable);  Slice<Task> findByName(String name, Pageable pageable);  List<Task> findByName(String name, Sort sort);}

利用Distinct去重

interface TaskDao extends JpaRepository<Task, Long> {    List<Person> findDistinctTaskByNameOrProjectId(String name, Long projectId);}

利用OrderBy进行排序

interface TaskDao extends JpaRepository<Task, Long> {    List<Person> findByNameOrderByProjectIdDesc(String name, Long projectId);}

利用 Top 和 First来获取限制数据

interface TaskDao extends JpaRepository<Task, Long> {    User findFirstByOrderByLastnameAsc();Task findTopByOrderByNameDesc(String name);Page<Task> queryFirst10ByName(String name, Pageable pageable);Slice<Task> findTop3ByName(String name, Pageable pageable);List<Task> findFirst10ByName(String name, Sort sort);List<Task> findTop10ByName(String name, Pageable pageable);}

那么spring data jpa是怎么通过这些规范来进行组装成查询语句呢?

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

假如创建如下的查询:findByTaskProjectName(),框架在解析该方法时,首先剔除 findBy,然后对剩下的属性进行解析,假设查询实体为Doc

  • 先判断 taskProjectName (根据 POJO 规范,首字母变为小写)是否为查询实体的一个属性,如果是,则表示根据该属性进行查询;如果没有该属性,继续第二步;

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

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

  • 可能会存在一种特殊情况,比如 Person包含一个 task 的属性,也有一个 projectName 属性,此时会存在混淆。可以明确在属性之间加上 “_” 以显式表达意图,比如 “findByTask_ProjectName()”

支持的规范表达式

这里以实体为User,有firstName和lastName,age

表达式例子hql查询语句
AndfindByLastnameAndFirstname&hellip; where x.lastname = ?1 and x.firstname = ?2
OrfindByLastnameOrFirstname&hellip; where x.lastname = ?1 or x.firstname = ?2
Is,EqualsfindByFirstname,findByFirstnameIs,findByFirstnameEqual&hellip; where x.firstname = 1?
BetweenfindByStartDateBetween&hellip; where x.startDate between 1? and ?2
LessThanfindByAgeLessThan&hellip; where x.age < ?1
LessThanEqualfindByAgeLessThanEqual&hellip; where x.age &lArr; ?1
GreaterThanfindByAgeGreaterThan&hellip; where x.age > ?1
GreaterThanEqualfindByAgeGreaterThanEqual&hellip; where x.age >= ?1
AfterfindByStartDateAfter&hellip; where x.startDate > ?1
BeforefindByStartDateBefore&hellip; where x.startDate < ?1
IsNullfindByAgeIsNull&hellip; where x.age is null
IsNotNull,NotNullfindByAge(Is)NotNull&hellip; where x.age not null
LikefindByFirstnameLike&hellip; where x.firstname like ?1
NotLikefindByFirstnameNotLike&hellip; where x.firstname not like ?1
StartingWithfindByFirstnameStartingWith&hellip; where x.firstname like ?1 (parameter bound with appended %)
EndingWithfindByFirstnameEndingWith&hellip; where x.firstname like ?1 (parameter bound with prepended %)
ContainingfindByFirstnameContaining&hellip; where x.firstname like ?1 (parameter bound wrapped in %)
OrderByfindByAgeOrderByLastnameDesc&hellip; where x.age = ?1 order by x.lastname desc
NotfindByLastnameNot&hellip; where x.lastname <> ?1
InfindByAgeIn(Collection ages)&hellip; where x.age in ?1
NotInfindByAgeNotIn(Collection age)&hellip; where x.age not in ?1
TruefindByActiveTrue()&hellip; where x.active = true
FalsefindByActiveFalse()&hellip; where x.active = false
IgnoreCasefindByFirstnameIgnoreCase&hellip; where UPPER(x.firstame) = UPPER(?1)

读到这里,这篇“spring data jpa怎么创建方法名进行简单查询”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

spring data jpa怎么创建方法名进行简单查询

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

spring data jpa怎么创建方法名进行简单查询

本文小编为大家详细介绍“spring data jpa怎么创建方法名进行简单查询”,内容详细,步骤清晰,细节处理妥当,希望这篇“spring data jpa怎么创建方法名进行简单查询”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录