温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JPA怎么使用findBy方法自定义查询

发布时间:2021-11-25 13:15:18 来源:亿速云 阅读:289 作者:小新 栏目:开发技术

这篇文章给大家分享的是有关JPA怎么使用findBy方法自定义查询的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

JPA使用findBy方法自定义查询

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

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

JPA怎么使用findBy方法自定义查询

在postman测试请求的接口如下

JPA怎么使用findBy方法自定义查询

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

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方法自定义查询”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI