我可以用
findBy这种方式吗?部门findByDepartmentId(Long Id);
是的,从Spring JPA的角度来看,此语法在技术上是正确的。尽管Spring JPA还会通过查询 返回类型 来推断您要通过查询实现的目标。
与查询要返回一个值-您可以指定
basic type
,Entity T
,Optional<T>
,CompletableFuture<T>
等。与查询要返回T的集合-你可以指定
List<T>
,Stream<T>
,Page<T>
,Slice<T>
等。
话虽如此,您的查询定义:
Department findByDepartmentId(Long Id);
表示您希望得到一个结果(因为您已将其指定
Entity T为返回类型)。这将反映出Spring JPA如何执行查询-
它将
getSingleResult()在
javax.persistence.Query接口上调用,
exception如果一个以上的对象满足条件,则该接口将抛出。
在什么基础上
findBydepartmentId返回单个记录?
基于具有该ID的单个对象,否则它将引发异常。
什么时候或为什么不应该
findBy代替findOneBy?
这两个具有不同的含义并且不可互换。
findOneBy总是导致
getSingleResult()被调用。
findBy根据返回类型的不同,行为也不同-根据上面给出的定义。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)