我是靠谱客的博主 耍酷故事,最近开发中收集的这篇文章主要介绍JPA如何使用findBy方法自定义查询,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

JPA使用findBy方法自定义查询

最近在项目中使用spring boot+jpa的方式来访问数据库,例如:本项目中的课程目录详情表中包括了外键课程详情ID,想通过课程详情ID查找出所有关联的课程目录详情

在JPA中使用findBy方法自定义查询

在postman测试请求的接口如下

这样就很方便的查询所需要的数据,不用再写接口去过滤了。

JPA的findBy语法整理

前提操作

  • 创建一个可持久化的实体类
  • dao层继承JpaRepository<T,ID>

T:实体类

ID:实体类的主键类型

例:

public interface SysUserRespository extends JpaRepository<SysUser,Long> {}

JPA中支持的关键词

  • And:等价于 SQL 中的 and 关键字,比如 findByUsernameAndPassword(String user, Striang pwd);
  • Or:等价于 SQL 中的 or 关键字,比如 findByUsernameOrAddress(String user, String addr);
  • Between:等价于 SQL 中的 between 关键字,比如 findBySalaryBetween(int max, int min);
  • LessThan:等价于 SQL 中的 "<",比如 findBySalaryLessThan(int max);
  • GreaterThan:等价于 SQL 中的">",比如 findBySalaryGreaterThan(int min);
  • IsNull:等价于 SQL 中的 "is null",比如 findByUsernameIsNull();
  • IsNotNull:等价于 SQL 中的 "is not null",比如 findByUsernameIsNotNull();
  • NotNull:与 IsNotNull 等价;
  • Like:等价于 SQL 中的 "like",比如 findByUsernameLike(String user);
  • NotLike:等价于 SQL 中的 "not like",比如 findByUsernameNotLike(String user);
  • OrderBy:等价于 SQL 中的 "order by",比如 findByUsernameOrderBySalaryAsc(String user);
  • Not:等价于 SQL 中的 "! =",比如 findByUsernameNot(String user);
  • In:等价于 SQL 中的 "in",比如 findByUsernameIn(Collection<String> userList) ,方法的参数可以是 Collection 类型,也可以是数组或者不定长参数;
  • NotIn:等价于 SQL 中的 "not in",比如 findByUsernameNotIn(Collection<String> userList) ,方法的参数可以是 Collection 类型,也可以是数组或者不定长参数;

以上为个人经验,希望能给大家一个参考,也希望大家多多支持靠谱客。

最后

以上就是耍酷故事为你收集整理的JPA如何使用findBy方法自定义查询的全部内容,希望文章能够帮你解决JPA如何使用findBy方法自定义查询所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(236)

评论列表共有 0 条评论

立即
投稿
返回
顶部