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

Spring Data JPA中findBy和findOneBy之间的区别,第1张

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

我可以用

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
根据返回类型的不同,行为也不同-根据上面给出的定义。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5045955.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-15
下一篇 2022-11-15

发表评论

登录后才能评论

评论列表(0条)

保存