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

发布时间:2022-02-23 13:47:16 作者:iii
来源:亿速云 阅读:157

本文小编为大家详细介绍“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,然后复制一些方法到你的接口中,可以选择性的要一些方法

@NoRepositoryBean
interface 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

支持的规范表达式

这里以实体为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怎么创建方法名进行简单查询”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. Spring Data JPA 实例查询
  2. Spring Data JPA 简单查询

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

spring data jpa

上一篇:python执行SQL语句怎么实现

下一篇:SQL中的Case语句怎么用

相关阅读

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

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