小编典典

Spring Data JPA中findBy和findOneBy之间的区别

spring-boot

到目前为止,我所知道的是,FindBy可以返回多个结果,而FindOneBy将以以下方式返回单个结果或为null。

List<Department> findByDepartmentName(String name);
Department findOneByDepartmentId(Long Id);

现在,我的问题是,我可以这样使用findBy吗?

Department  findByDepartmentId(Long Id);

如是,

  • 假设给定ID有多个记录。
  • findBydepartmentId 在什么基础上 返回单个记录?

最后,何时或为何不应该使用findBy代替findOneBy?


阅读 3462

收藏
2020-05-30

共1个答案

小编典典

我可以用findBy这种方式吗?部门 findByDepartmentId(Long Id);

是的,从Spring JPA的角度来看,此语法在技术上是正确的。尽管Spring JPA还会通过查询 返回类型 来推断您要通过查询实现的目标。

基本上,这些是返回类型的情况:

话虽如此,您的查询定义:

Department findByDepartmentId(Long Id);

表示您希望得到一个结果(因为您已将其指定Entity T为返回类型)。这将反映出Spring JPA如何执行查询-
它将getSingleResult()javax.persistence.Query接口上调用,exception如果一个以上的对象满足条件,则该接口将抛出。

在什么基础上findBydepartmentId返回单个记录?

基于具有该ID的单个对象,否则它将引发异常。

什么时候或为什么不应该findBy代替findOneBy

这两个具有不同的含义并且不可互换。

findOneBy总是导致getSingleResult()被调用。

findBy 根据返回类型的不同,行为也不同-根据上面给出的定义。

2020-05-30